佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > MySQL中參數(shù)sql_safe_updates在生產(chǎn)環(huán)境的使用詳解

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

熱門標(biāo)簽:服務(wù)外包 Linux服務(wù)器 呼叫中心市場需求 百度競價(jià)排名 AI電銷 地方門戶網(wǎng)站 鐵路電話系統(tǒng) 網(wǎng)站排名優(yōu)化

前言

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

set sql_safe_updates = 1;

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

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()); 

# 過濾字段上沒有索引
update
update 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: 0

update test01 set name = 'hhh' where age = 9 limit 10;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0

alter 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 column

update 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í),在沒有 where 條件或者where 后不是索引字段時(shí),必須使用 limit ;在有 where 條件時(shí),為索引字段

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

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

結(jié)果有一天開發(fā)發(fā)現(xiàn)下面的一個(gè)SQL 沒法正確執(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

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

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

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=? 來批量更新過。建議還是用程序處理,臨時(shí)修改變量不是長久之計(jì)。

總結(jié)

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

您可能感興趣的文章:
  • MySQL UPDATE更新語句精解
  • Mysql聯(lián)表update數(shù)據(jù)的示例詳解
  • 實(shí)例驗(yàn)證MySQL|update字段為相同的值是否會(huì)記錄binlog
  • mysql update語句的執(zhí)行過程詳解
  • MySQL select、insert、update批量操作語句代碼實(shí)例
  • Mysql update多表聯(lián)合更新的方法小結(jié)
  • MySQL執(zhí)行update語句和原數(shù)據(jù)相同會(huì)再次執(zhí)行嗎
  • mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解
  • Mysql Update批量更新的幾種方式
  • MYSQL updatexml()函數(shù)報(bào)錯(cuò)注入解析
  • mysql中錯(cuò)誤:1093-You can’t specify target table for update in FROM clause的解決方法
  • mybatis執(zhí)行批量更新batch update 的方法(oracle,mysql兩種)
  • 記一次MySQL更新語句update的踩坑

標(biāo)簽:崇左 銅川 湘潭 黃山 衡水 仙桃 蘭州 湖南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL中參數(shù)sql_safe_updates在生產(chǎn)環(huán)境的使用詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    克什克腾旗| 云浮市| 镇平县| 名山县| 正阳县| 龙口市| 广河县| 湘乡市| 西城区| 台州市| 祁连县| 杭锦后旗| 开平市| 正镶白旗| 高唐县| 莱西市| 东乡族自治县| 高邮市| 呼图壁县| 安西县| 布尔津县| 渑池县| 安丘市| 奇台县| 江都市| 临汾市| 徐汇区| 东光县| 新野县| 成安县| 白山市| 布尔津县| 昌黎县| 巧家县| 乌苏市| 兴安盟| 嘉禾县| 咸阳市| 石首市| 新疆| 师宗县|