成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > MySQL update set 和 and的區(qū)別

MySQL update set 和 and的區(qū)別

熱門標簽:武漢電銷機器人電話 催天下外呼系統(tǒng) html地圖標注并導(dǎo)航 南太平洋地圖標注 400電話變更申請 呂梁外呼系統(tǒng) 400電話辦理服務(wù)價格最實惠 大豐地圖標注app 北京金倫外呼系統(tǒng)

問題描述

最近接到一個奇怪的咨詢,update 語句執(zhí)行沒有報錯,但是沒有更新數(shù)據(jù),具體有問題的語句類似于如下形式:

update test.stu set cname = '0' and math = 90 and his = 80 where id = 100;

原因分析

直觀上看,這個 update 語句的語法是有問題的,正常更新多列數(shù)據(jù)的語法應(yīng)該是用逗號,類似于如下形式:

update test.stu set cname = '0',math = 90,his = 80 where id = 100;

直接用 and 第一反應(yīng)其實是會報語法錯誤,不太像是能正常執(zhí)行的。那么基于騰訊云數(shù)據(jù)庫 MySQL,實際構(gòu)造一個簡單的場景,嘗試復(fù)現(xiàn)一下這個問題。

SQL 語句如下:

CREATE TABLE `stu` (
  `id` int(11) NOT NULL,
  `sname` varchar(16) NOT NULL,
  `cname` varchar(8) DEFAULT NULL,
  `math` int(11) NOT NULL,
  `eng` int(11) DEFAULT NULL,
  `his` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

insert into stu values(100,'sam','0',90,88,83);
insert into stu values(101,'jhon','1',97,82,81);
insert into stu values(102,'mary','2',87,89,92);
insert into stu values(103,'adam','2',87,89,92);

然后分別試一試正常的 update 語句和使用 and 的 update 語句,看一下實際的運行結(jié)果:

mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> update test.stu set cname = '0' and math = 90 and his = 80 where id = 100;
Query OK, 0 rows affected (0.00 sec)
Rows matched: 1  Changed: 0  Warnings: 0

mysql> select * from stu;
+-----+-------+-------+------+------+------+
| id  | sname | cname | math | eng  | his  |
+-----+-------+-------+------+------+------+
| 100 | sam   | 0     |   90 |   88 |   83 |
| 101 | jhon  | 1     |   97 |   82 |   81 |
| 102 | mary  | 2     |   87 |   89 |   92 |
| 103 | adam  | 2     |   87 |   89 |   92 |
+-----+-------+-------+------+------+------+
4 rows in set (0.00 sec)

mysql> update test.stu set cname = '0',math = 90,his = 80 where id = 100;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from stu;
+-----+-------+-------+------+------+------+
| id  | sname | cname | math | eng  | his  |
+-----+-------+-------+------+------+------+
| 100 | sam   | 0     |   90 |   88 |   80 |
| 101 | jhon  | 1     |   97 |   82 |   81 |
| 102 | mary  | 2     |   87 |   89 |   92 |
| 103 | adam  | 2     |   87 |   89 |   92 |
+-----+-------+-------+------+------+------+
4 rows in set (0.00 sec)

mysql> rollback;
Query OK, 0 rows affected (0.01 sec)

mysql>

可以看到這兩個語句確實都不會報錯,且?guī)?and 的 update 語句匹配到了具體的行(Rows matched: 1),但是沒有修改數(shù)據(jù)(Changed: 0),標準語法下的 update 語句倒是正常修改了數(shù)據(jù)。

由此可見,MySQL 在語法上,并不認為 and 這個用法是錯誤的,那么說明 MySQL 用另外的方式“解讀”了這個語句。最容易想到的,就是 MySQL 是不是在 set 的時候,把 and 解釋成了邏輯運算符,而不是英文意義上的“和”?而且 cname 的取值本來就是 0,也符合數(shù)據(jù)庫處理 bool 數(shù)據(jù)時的行為(用 0 和 1 代替 False 和 True)。

驗證起來很簡單,換個 cname 不為 0 的數(shù)據(jù) update 一下就可以了:

mysql> select * from stu;
+-----+-------+-------+------+------+------+
| id  | sname | cname | math | eng  | his  |
+-----+-------+-------+------+------+------+
| 100 | sam   | 0     |   90 |   88 |   83 |
| 101 | jhon  | 1     |   97 |   82 |   81 |
| 102 | mary  | 2     |   87 |   89 |   92 |
| 103 | adam  | 2     |   87 |   89 |   92 |
+-----+-------+-------+------+------+------+
4 rows in set (0.00 sec)

mysql> begin;update test.stu set cname = '0' and math = 90 and his = 80 where id = 101;
Query OK, 0 rows affected (0.00 sec)

Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from stu;
+-----+-------+-------+------+------+------+
| id  | sname | cname | math | eng  | his  |
+-----+-------+-------+------+------+------+
| 100 | sam   | 0     |   90 |   88 |   83 |
| 101 | jhon  | 0     |   97 |   82 |   81 |
| 102 | mary  | 2     |   87 |   89 |   92 |
| 103 | adam  | 2     |   87 |   89 |   92 |
+-----+-------+-------+------+------+------+
4 rows in set (0.00 sec)

mysql> rollback;
Query OK, 0 rows affected (0.00 sec)

從結(jié)果來看,MySQL 修改 cname 的值為 0,說明確實是當成邏輯運算符來處理了,仔細分析這個語句,會發(fā)現(xiàn) MySQL 按照如下方式來處理:

set cname = ('0' and math = 90 and his = 80)

math 和 his 的取值是根據(jù) where 條件篩選的行來決定的,實際對應(yīng)到上面測試的場景,會變成如下的邏輯判斷:

'0' and 97 = 90 and 81 = 80

PS:需要注意,即便是字符型的數(shù)據(jù) 0,也會被當做 False。

解決方案

目前并不能通過 sql_mode 或者其他參數(shù)的形式來阻止這種帶 and 的 update 語句,因此這一類問題的隱蔽性比較強。建議在開發(fā)的時候,利用封裝好的框架,或者加強代碼或者 SQL review 來避免這個問題。

PS:騰訊云數(shù)據(jù)庫 MySQL 也會有類似的問題,需要警惕。

以上就是MySQL update set 和 and的區(qū)別的詳細內(nèi)容,更多關(guān)于MySQL update set 和 and的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • 實操MySQL+PostgreSQL批量插入更新insertOrUpdate
  • MySQL UPDATE 語句的非標準實現(xiàn)代碼
  • mysql update case 更新字段值不固定的操作
  • Mysql update多表聯(lián)合更新的方法小結(jié)
  • mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解
  • MySQL UPDATE 語句一個“經(jīng)典”的坑

標簽:龍巖 自貢 麗水 南充 西寧 徐州 迪慶 無錫

巨人網(wǎng)絡(luò)通訊聲明:本文標題《MySQL update set 和 and的區(qū)別》,本文關(guān)鍵詞  MySQL,update,set,和,and,的,區(qū)別,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL update set 和 and的區(qū)別》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL update set 和 and的區(qū)別的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    久草这里只有精品视频| 国产麻豆一区二区三区精品视频| 91欧美一区二区三区| 波多野结衣av在线播放| 欧美日韩1区2区| 亚洲欧洲av一区二区三区久久| 亚洲激情免费观看| 亚洲免费在线电影| 热久久最新网址| av网站在线免费看推荐| 国产欧美一区二区三区在线| 久久久成人av毛片免费观看| 国产18精品乱码免费看| 国产一区二区免费看| 黄页网站在线观看免费| 欧美特级aaa| 国产厕拍一区| 久久99热精品| 久久久美女毛片| 美女视频黄免费的久久| 久久久之久亚州精品露出| 亚洲国产精品久久久久| 91日韩在线播放| 国产一区二区导航在线播放| 岛国最新视频免费在线观看| 91蜜桃传媒精品久久久一区二区| 濑亚美莉vs黑人在线观看| 亚洲天堂av免费在线观看| 福利小视频在线观看| 精品久久网站| 日本午夜免费福利视频| 亚洲国产精品久久人人爱潘金莲| 日韩在线看片| 欧美99在线视频观看| 欧美老女人性视频| 国产综合欧美| 亚洲美女免费精品视频在线观看| 日韩高清不卡一区| 久久er99热精品一区二区三区| 69久久精品无码一区二区| 日本中文字幕久久看| av网站在线播放| 欧美激情成人在线视频| 91浏览器在线视频| 亚洲免费电影一区| 你懂的一区二区| 国产一区二区你懂的| 国产精品视频男人的天堂| 久久久高清一区二区三区| 精品一区二区三区在线观看视频| 一区二区三区在线资源| 欧美日韩一区二区三区四区五区六区| 5566中文字幕| 欧美日韩不卡合集视频| 无码人妻av一区二区三区波多野| 国产麻豆剧果冻传媒观看hd高清| 亚洲成av人片在线观看www| 91精品国产自产在线观看永久∴| 91视频免费进入| 老司机精品福利在线观看| 超碰在线公开| 国产精品视频免费在线| 青青草国产一区二区三区| 波多野结衣一二三区| 综合五月婷婷| 一区二区三区国产盗摄| 亚洲av无码专区在线播放中文| 日韩经典中文字幕一区| 欧美另类交人妖| 亚洲最新视频在线播放| 亚洲午夜极品| 一本一本久久a久久精品牛牛影视| 缅甸午夜性猛交xxxx| 国产亚洲毛片在线| 欧美激情专区| 91在线短视频| 国产精品入口芒果| 精品一区二区三区久久| 日本精品一区二区三区高清 久久| 免费观看国产精品| 国产精品一在线观看| 亚洲第一久久影院| 久久中文字幕在线观看| 蜜桃一区二区三区四区| 国产亚洲精品美女久久久| 国产高清精品二区| 色偷偷偷综合中文字幕;dd| 国产 日韩 亚洲 欧美| 2019年精品视频自拍| 久久在线视频在线| 日日干夜夜草| 又色又爽的视频| 麻豆精品永久免费视频| 国产成人免费网站| 亚洲18在线看污www麻豆| 丁香综合在线| 日本韩国精品一区二区在线观看| 9999在线视频| 一本一道波多野毛片中文在线| 国产目拍亚洲精品99久久精品| 噜噜噜在线视频| 少妇的滋味中文字幕bd| 天天色天天操天天做| 麻豆成人在线播放| 一级毛片美女欧洲| 亚洲裸色大胆大尺寸艺术写真| 九九热在线观看视频| 欧美一级高清大全免费观看| 日日摸天天添天天添破| 亚洲影视一区| 一区二区三区四区视频免费观看| 日韩精品最新在线观看| 亚洲欧美日韩另类精品一区二区三区| 91嫩草国产在线观看| 欧美成人精精品一区二区频| 国产亚洲一区二区手机在线观看| 97av视频在线| 久久精品日产第一区二区三区乱码| 亚洲动漫第一页| 日韩精品欧美成人高清一区二区| 亚洲区一区二区三| 国产成人精品一区二区三区视频| 国产日韩av高清| 中文字幕中文字幕99| 日韩欧美一区二区在线视频| 国产网站欧美日韩免费精品在线观看| 国外成人免费在线播放| 人人妻人人澡人人爽精品日本| 日本美女一区二区三区| 极品盗摄国产盗摄合集| 日本成人免费| 曰本三级在线| 国产夜色精品一区二区av| 精品一区二区三区在线观看国产| 深夜影院在线观看| 欧美日韩不卡在线视频| 日本亚洲欧美美色| 在线观看国产精品91| 国产美女精品一区二区三区| av观看网址| 成人免费无遮挡无码黄漫视频| 欧美极品少妇xxxxⅹ免费视频| 日本人妖在线| 成人在线免费观看视频网站| 亚洲综合在线做性| 视频在线99| 最美情侣韩剧在线播放| 国产成人成网站在线播放青青| 日本三级久久久| 日韩欧美在线一区二区三区| 国产一区二区精品久| 欧美一区二区三区四区高清| 欧美人与牲动交xxxxbbbb| a网站在线观看| 午夜cr在线观看高清在线视频完整版| 91久久精品www人人做人人爽| 黄色大全在线观看| 日韩色图在线观看| 黄色网在线播放| 熟女熟妇伦久久影院毛片一区二区| 亚洲a级黄色片| 一本大道亚洲视频| 国产视频一区在线观看| 91在线中字| 中文字幕在线看精品乱码| 男人添女人下部视频免费| 色综合天天做天天爱| 九九热免费精品视频| 中文无字幕一区二区三区| 精品国产乱码久久久久久久软件| 久久精品一区二区三区四区五区| 色婷婷久久久亚洲一区二区三区| yy111111少妇嫩草影院| 午夜免费福利在线| 国产精品夜夜夜爽张柏芝| 精品成人自拍视频| 91精品综合久久久久久| 国产成人av电影在线观看| 久久久精品五月天| 99久久久久成人国产免费| 91肉色超薄丝袜脚交一区二区| 欧美日韩国产精品一区| 欧美日韩精品在线视频| 国产盗摄在线视频网站| 男女啪啪在线观看| 超碰精品在线观看| 香蕉视频国产在线| 香蕉视频免费在线播放| 成人拍拍拍免费视频网站| 99久久99精品| 国产成人精品免费看在线播放| 欧美日韩国产综合新一区| 国产视频一区在线观看| 狠狠操夜夜操| 无遮挡aaaaa大片免费看| 国精产品一品二品国精品69xx| 成人在线免费看片| 懂色中文一区二区三区在线视频| 国产porny蝌蚪视频| 羞羞答答一区二区| 国产一区二区日韩精品欧美精品| 亚洲手机在线| 久热国产精品视频一区二区三区| av在线之家电影网站| 中文字幕人成不卡一区| 日本成人中文字幕在线视频| 亚洲天堂成人在线| 国产尤物99| av资源中文在线天堂| 91九色视频蝌蚪| 欧美一级视频免费看| 久久精品国内一区二区三区| 国产精品无码久久久久久| 人妻少妇无码精品视频区| 幼a在线观看| 久久久久.com| 国产日韩精品电影| 日韩高清免费在线| 精品久久久国产精品999| 日韩中文字幕区一区有砖一区| 免费黄色成年网站| 五月天色一区| 国产成人av毛片| 草草久久久无码国产专区| 91福利免费观看| 性一交一乱一伧国产女士spa| 91看片在线免费观看| 欧美色图片区| 一级黄色录像大片| 欧美特黄一级| 在线不卡视频一区二区| 欧美在线免费观看亚洲| 日韩avvvv在线播放| 无码一区二区精品| 精品亚洲成a人在线观看| 欧美性色黄大片人与善| 女人天堂在线视频| 视频一区免费在线观看| 精品影视av免费| 国产精品久久久久久久久久久久久久久| 美女毛片一区二区三区四区最新中文字幕亚洲| 精品亚洲a∨一区二区三区18| 欧美一级艳片视频免费观看| 99riav国产精品| 国产精品女同互慰在线看| 四虎影视4hu4虎成人| 亚洲在线www| 成人黄在线观看| 成人福利在线观看视频| 好男人中文字幕官网| 欧美日韩1区2区| 国产iv一区二区三区| 91传媒免费看| 午夜成人在线视频| 日本一区二区三区四区高清视频| 久久97人妻无码一区二区三区| 亚洲精品激情| 浮妇高潮喷白浆视频| 国产精品久久久久精k8| 免费在线观看羞羞视频| 亚洲新中文字幕| 精品久久人人做人人爰| 1000精品久久久久久久久| 久久久国产精品一区二区三区| 在线免费成人| 在线成人国产| 综合色就爱涩涩涩综合婷婷| 天堂а√在线中文在线新版| a天堂资源在线观看| 国产成人的电影在线观看| 深夜做爰性大片蜜桃| 天堂av一区| 91精品国产综合久久香蕉的用户体验| 国产一二三区在线视频| 中文字幕欧美人与畜| 欧美久久综合| 精品久久久久久久久久久国产字幕| 国产精品igao视频| 欧美日韩第一视频| 久久不射网站| 亚洲www在线| 国产成人久久久| 亚洲天堂久久| 黄色动漫在线观看| 国模私拍国内精品国内av| 亚洲免费一级视频| 99久久久国产| 久久精品视频在线看| 久草免费新视频| 日韩精品视频免费看| 黄瓜视频成人app免费| 青青草免费在线观看| 久久三级视频| 男人通一通女人的下水道| 精品国产电影| 亚洲福利久久| 裸体一区二区三区| 精品人妻人人做人人爽夜夜爽| 久草网在线视频| 中文字幕成人乱码在线电影| 亚洲人成在线一二| 91精品国产欧美一区二区成人| 日韩美女啊v在线免费观看| 色一情一乱一乱一91av| 成本人h片动漫网站在线观看| 亚洲综合区在线| 久久久青草婷婷精品综合日韩| 久久精品国内一区二区三区| 亚洲日本精品国产第一区| 国产无套精品一区二区| 色综合久久综合中文综合网| 色噜噜日韩精品欧美一区二区| 欧美三级电影一区| 精品午夜久久福利影院| 国产免费av网站| 黄色a级三级三级三级| 成人免费在线观看| 美国成人xxx| 日本a在线免费观看| 97久久人国产精品婷婷| 欧美日韩中文字幕| 色综久久综合桃花网| 91日韩在线视频| 97久久精品人人做人人爽| 欧美日韩一区 二区 三区 久久精品| 亚洲天堂电影在线观看| 国产www免费| 欧美伦理视频在线观看|