开发者社区> 问答> 正文

sql中update语句 and 和直接where语句的区别是什么?

现在我有如下两条sql请问有什么区别?
update customer set moeny = 100 and balance >= 100

udpate customer set money =100 where balance >= 100

展开
收起
a123456678 2016-07-04 14:56:42 4266 0
1 条回答
写回答
取消 提交回答
  • 先说正确的写法
    udpate customer set money =100 where balance >= 100
    所有balance >=100 的money=100

    再说错误的
    update customer set moeny = 100 and balance >= 100
    这个错误很严重,会把全局的money变为默认值,通常是0

    原因是:没有where则为全局set ,set里面多个设置方式是采用',';如果用了and 会认为是对money的设定,money = (100 and balance >=100),但是,这个表达式的值无法识别,会变为默认值。

    因此:全局的money变成了默认值,很坑爹的,delete和update千万记得加where,尤其update,因为delete还有提醒。

    2019-07-17 19:50:41
    赞同 1 展开评论 打赏
问答分类:
SQL
问答地址:
问答排行榜
最热
最新

相关电子书

更多
SQL Server 2017 立即下载
GeoMesa on Spark SQL 立即下载
原生SQL on Hadoop引擎- Apache HAWQ 2.x最新技术解密malili 立即下载