首页 > 代码库 > MySql SELECT INTO 记录为空的问题

MySql SELECT INTO 记录为空的问题


      SELECT Id INTO @Id FROM GiftCode WHERE Status = 1 AND GiftId = #GiftId# ORDER BY Id ASC LIMIT 1;
      UPDATE GiftCode SET UsedTime = NOW(),Status = 2,AccountId = #AccountId# WHERE Id = @Id;
      SELECT * FROM GiftCode WHERE Id = @Id;

 

如题,这3句SQL,在SQLSERVER中是没有问题的,如果在MYSQL中,会因为第一句没有查找到记录,影响行数为0,不会执行INTO的操作

@Id的变量,会维持前一次会话中的结果。(@是会话变量),造成程序问题

 

解决办法:

在最前面加一句:      SET @Id = 0;

就可以解决,如果有更好的解决办法,请回帖!

 

环境:asp.net framework 3.5/ibatis.net/mysql

MySql SELECT INTO 记录为空的问题