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
时间: 2024-10-11 17:14:53