久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

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

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

瀏覽:23日期: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 數據庫
相關文章:
主站蜘蛛池模板: 衡南县| 罗源县| 南陵县| 东源县| 汨罗市| 南汇区| 周宁县| 桐城市| 闽侯县| 鄄城县| 平和县| 平凉市| 阿坝| 修武县| 都安| 新建县| 县级市| 黄梅县| 隆德县| 泗阳县| 潞西市| 新宾| 定州市| 徐州市| 卢湾区| 葫芦岛市| 五华县| 梁山县| 阳新县| 西乌珠穆沁旗| 高阳县| 桃江县| 蛟河市| 广平县| 清镇市| 巢湖市| 柯坪县| 托克托县| 北辰区| 郧西县| 博湖县|