久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

記一次MySQL更新語句update的踩坑

瀏覽:3日期:2023-10-08 14:37:40

背景

最近在一次線上作業過程中執行了一句DML語句,本以為萬無一失,結果應用反饋說沒有更新,數據還是沒有變,最后經過排查才發現是我語句寫錯了,導致update語句執行的結果與預期不符。

情景再現

為了方便演示,建立一張用戶表,同時插入五條數據。

create table user(id int(12) comment ’用戶主鍵id’,name varchar(36) comment ’用戶名’,age int(12) comment ’年齡’);insert into user values (1,’one’,11),(2,’two’,12),(3,’three’,13),(4,’four’,15),(5,’five’,15);

執行完成后,現在user表中的數據如下:

+------+-------+------+| id | name | age |+------+-------+------+| 1 | one | 11 || 2 | two | 12 || 3 | three | 13 || 4 | four | 15 || 5 | five | 15 |+------+-------+------+

現在需要把所有的年齡改成 10、用戶名改成user——假設此操作有意義——我提交到運維的 DML 語句如下:

update user set age=10 and name=’user’;

當我刷新用戶表,看到執行update語句后的表全部數據如下:

+------+-------+------+| id | name | age |+------+-------+------+| 1 | one | 0 || 2 | two | 0 || 3 | three | 0 || 4 | four | 0 || 5 | five | 0 |+------+-------+------+

神奇的事情發生了,age字段全部被更新成0,而name字段竟然沒有任何修改!

錯誤原因及修正

錯誤原因其實很簡單,update語句寫錯了。MySQL中update語句的語法是

UPDATE table_nameSET column1=value1,column2=value2,...WHERE some_column=some_value;```sql如果更新多個字段,相鄰字段間應該以逗號分隔而不是`and`。如果 update 語句使用 and 作為多個字段之間的分隔符,就像最開始我提交給運維的那樣,這個更新語句最終將會變成```sqlupdate user set age=(10 and name=’user’);

而(10 and name=’user’)作為一個返回值為 boolean 類型的判斷語句,返回會被映射成 1 或 0,有 99.999% 的可能會讓第一個更新變量更新為錯誤的數據。

正確的更新語句應該是

update user set age=10, name=’user’;

教訓

在提交DML語句前先在測試環境試一下基礎的SQL語法不要記錯

小結

MySQL中update語句的語法是

UPDATE table_nameSET column1=value1,column2=value2,...WHERE some_column=some_value;

以上就是記一次MySQL更新語句update的踩坑的詳細內容,更多關于MySQL更新語句update的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 欧美 日韩 国产 成人 在线 | 精品视频久久久 | 亚洲综合中文网 | 天天躁人人躁人人躁狂躁 | 亚洲毛片 | 国产精品美女视频免费观看软件 | 精品国产乱码久久久久久1区2区 | 永久av | 日韩中文字幕在线播放 | 欧美一区二区三区精品免费 | 国产成人精品一区二区三区视频 | 国产中文在线 | 国产9色在线 | 日韩 | 黄色国产在线看 | 激情久久久久 | 午夜电影在线看 | 99爱在线观看 | 国产精品乱码一区二区三区 | 久久精品国产99国产精品 | 日韩欧美成人一区二区三区 | 亚洲毛片在线 | 91传媒在线播放 | 国产精品日韩欧美一区二区三区 | 欧美成人精品在线 | 亚洲一区二区三区免费观看 | 国产视频中文字幕 | 韩日一区二区 | 久久青青 | 99在线免费视频 | 毛片久久久 | 中文字幕在线播放一区 | 欧美日韩精品一区二区三区 | 美女天堂网 | www.99热| 久久av一区二区三区 | 国产精品污www一区二区三区 | 男女网站在线观看 | 福利视频一 | 亚洲人成电影网 | 国产福利一区二区三区四区 | 免费观看成人毛片 |