【原创】Mysql Waring/Error&…

Mysql中执行 
update meta
set meta.name = "Hello-Word" and meta.first_id = 12381
where meta.name = old.meta.name and meta.name="";

命名一句很简单的语句,你能看出有什么问题吗?既然我写出来,肯定是有问题的啦!
这句话执行后,执行成功,但是不会修改数据,0行受影响!!!
特别注意,执行成功,0行受影响!(也是我不喜欢用别人写的sqlHelper的原因,增、删、改只返回true和false。。这不易于发现问题,执行成功不代表真的操作成功!)

那么来看下问题所在,返回一个警告-warning。
这是唯一可用的信息了,查看一下警告信息。(紧接着SQL执行后就查询,只记录最近一条执行的waring)
show warings;
可以看到 Mysql Truncated incorrect DOUBLE value  "Hello-Word",意思就是值类型不正确呗。
开始以为是"-"号出了问题,于是换成单引号、用concat、总之就是不行。。。

我是用百度翻了N页没出一条结果,我都怀疑是我的提问语句都不会组织了。。。
上高大上的 stackoverflow,第二条搜索结果《 Q: Mysql Truncated incorrect DOUBLE value》就能看到正确原因。
UPDATE 
    shop_category 
SET 
    name = 'Secolul XVI - XVIII' , --注意,此处应该是','逗号!
    name_eng = '16th to 18th centuries' 
WHERE 
    category_id = 4768

逗号和and的区别!切记!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值