首页 > 代码库 > 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 记录为空的问题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。