av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

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

瀏覽:13日期: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 數據庫
相關文章:
主站蜘蛛池模板: 欧美日韩在线一区二区 | 黑森林av | 黄色片中文字幕 | 欧美伦理一区二区 | 久久天天躁狠狠躁夜夜躁2014 | 国产美女一区二区三区 | 天天干夜夜拍 | www.国产.com| 亚洲午夜精品 | 久久综合在线 | 天天干夜夜草 | 韩日欧美| 夜夜欢天天干 | 国产麻豆xxxvideo实拍 | 日韩一二三 | 黄色综合网 | 九九热视频在线观看 | 午夜精品999 | 国产成人精品亚洲男人的天堂 | 黑人黄色一级片 | 日本精品在线观看 | 中文字幕在线一区二区三区 | 一级免费片 | 97精品超碰一区二区三区 | 亚洲在线免费视频 | 91一区二区三区 | 国产a区 | 精品福利在线 | 国产精品久久久一区二区三区 | 日韩精品久久久久久久酒店 | 深夜视频在线观看 | 99精品在线 | 亚洲精品一区二区三区在线 | 亚洲免费精品 | 亚洲精品三区 | 亚洲久久视频 | 国产一区免费在线观看 | 国产综合视频在线观看 | 一本一道久久a久久精品蜜桃 | 亚洲第一区视频 | 日韩视频在线观看 |