麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

MySQL中參數(shù)sql_safe_updates在生產(chǎn)環(huán)境的使用詳解

2024-07-24 13:15:04
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

在應(yīng)用 BUG或者 DBA誤操作的情況下,會(huì)發(fā)生對(duì)全表進(jìn)行更新:update delete 的情況。MySQL提供 sql_safe_updates 來(lái)限制次操作。

set sql_safe_updates = 1;

設(shè)置之后,會(huì)限制update delete 中不帶 where 條件的SQL 執(zhí)行,較嚴(yán)格。會(huì)對(duì)已有線上環(huán)境帶來(lái)不利影響。對(duì)新系統(tǒng)、應(yīng)用做嚴(yán)格審核,可以確保不會(huì)發(fā)生全表更新的問(wèn)題。

CREATE TABLE working.test01 (id INT NOT NULL AUTO_INCREMENT,NAME VARCHAR(20),age INT,gmt_created DATETIME,PRIMARY KEY(id)); insert into test01(name,age,gmt_created) values('xiaowang',2,now()); insert into test01(name,age,gmt_created) values('huahua',5,now());  insert into test01(name,age,gmt_created) values('gougou',9,now());  insert into test01(name,age,gmt_created) values('heihei',12,now());  insert into test01(name,age,gmt_created) values('baibai',134,now()); # 過(guò)濾字段上沒(méi)有索引updateupdate test01 set name = 'xiaoxiao' where age = 2 ;ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column# 全表更新update test01 set name = 'xiaoxiao';ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column# 加入limit的更新update test01 set name = 'xia' limit 1;Query OK, 1 row affected (0.00 sec)Rows matched: 1 Changed: 1 Warnings: 0# 新增索引create index idx_age on test01(age);update test01 set name = 'xiaoxiao' where age = 2;Query OK, 1 row affected (0.01 sec)Rows matched: 1 Changed: 1 Warnings: 0update test01 set name = 'hhh' where age = 9 limit 10;Query OK, 1 row affected (0.00 sec)Rows matched: 1 Changed: 1 Warnings: 0alter table test01 drop index idx_age;create index idx_age_name on test01(age,name);update test01 set age= 100 where name = 'hhh';ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY columnupdate test01 set age= 100 where name = 'hhh' limit 10;Query OK, 1 row affected (0.00 sec)Rows matched: 1 Changed: 1 Warnings: 0

由此,update 時(shí),在沒(méi)有 where 條件或者where 后不是索引字段時(shí),必須使用 limit ;在有 where 條件時(shí),為索引字段

最近在工作中又發(fā)現(xiàn)了一個(gè)問(wèn)題,mysql sql_safe_updates 不支持子查詢的更新。

考慮到開(kāi)發(fā)人員有時(shí)候不小心誤更新數(shù)據(jù),要求線上庫(kù)的 MySQL 實(shí)例都設(shè)置 sql_safe_updates=1 來(lái)避免沒(méi)有索引的 update、delete。

結(jié)果有一天開(kāi)發(fā)發(fā)現(xiàn)下面的一個(gè)SQL 沒(méi)法正確執(zhí)行:

update t1 set col2=1 where key1 in (select col2 from t2 where key2='ABcD');

錯(cuò)誤如下:

ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column

也就是說(shuō)沒(méi)法對(duì)沒(méi)有走到索引的where條件進(jìn)行更新。搜索了下發(fā)現(xiàn),的確不行。及時(shí) key1 和key2 分別是 t1、t2 的索引[我換成主鍵都不行] 。說(shuō)明是不支持子查詢的update。

google 了一下發(fā)現(xiàn)人家也問(wèn)過(guò)這個(gè)問(wèn)題。。

http://stackoverflow.com/questions/24314830/query-not-getting-executed-if-supplied-a-nested-sub-query

最后解決方法:

1)修改 session 級(jí)別的參數(shù): set sql_safe_updates=0; 執(zhí)行 update 操作。退出終端。

2)程序處理:先 select col2 from t2 where key2='ABcD' 獲取數(shù)據(jù),然后循環(huán)處理結(jié)果,并用 update t1 set col2=1 where key1=? 來(lái)批量更新過(guò)。建議還是用程序處理,臨時(shí)修改變量不是長(zhǎng)久之計(jì)。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)VeVb武林網(wǎng)的支持。  


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MYSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 草免费视频 | 国产精品一品二区三区四区18 | 久久精品中文字幕一区二区三区 | 26uuu成人人网图片 | 黑人三级毛片 | 亚洲精品午夜在线 | 免费观看视频在线观看 | 综合99| 日本不卡视频在线观看 | 黄网站在线播放视频免费观看 | 一级美女大片 | 在线视频观看国产 | 精品国产一区二区三区四区阿崩 | 国产剧情在线观看一区二区 | 免费观看黄视频 | 看免费毛片 | 久久男人的天堂 | 欧美精品99 | 免费专区 - 91爱爱 | 久久久久久亚洲国产精品 | 在线观看中文字幕av | 91网站永久免费看 | 欧美国产一区二区三区激情无套 | 97香蕉超级碰碰久久免费软件 | 92看片淫黄大片一级 | 成人毛片视频在线播放 | 久久久久久亚洲国产精品 | 免费看国产 | 午夜亚洲影院 | 免费观看一区 | 成人毛片网 | 国产亚洲精品久久久久久久久 | 久久九九热re6这里有精品 | 国产做爰全免费的视频黑人 | 国产女王女m视频vk 中文日韩 | 欧美韩国日本在线 | 特一级黄色毛片 | 丰满年轻岳中文字幕一区二区 | 久久久www成人免费精品 | 国产精品啪一品二区三区粉嫩 | 欧美视频在线一区二区三区 |