开发者社区> 问答> 正文

sql中update用and和用where子句有什么区别?

1.现在我有如下两条sql请问有什么区别?

update customer set moeny = 100 and balance >= 100
udpate customer set money  =100 where balance >= 100

展开
收起
蛮大人123 2016-02-13 11:00:33 4821 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 18:41:50
    赞同 展开评论 打赏
问答分类:
SQL
问答地址:
问答排行榜
最热
最新

相关电子书

更多
SQL Server在电子商务中的应用与实践 立即下载
GeoMesa on Spark SQL 立即下载
原生SQL on Hadoop引擎- Apache HAWQ 2.x最新技术解密malili 立即下载