欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年11月27日 09:51:01   作者:笱局長(zhǎng)  
這篇文章主要給大家介紹了關(guān)于MySQL中參數(shù)sql_safe_updates在生產(chǎn)環(huán)境使用的相關(guān)資料,并給大家分享了解決mysql sql_safe_updates不支持子查詢(xún)更新的方法,分享出來(lái)供大家參考學(xué)習(xí),需要的朋友們下面來(lái)一起看看吧。

前言

在應(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ì)已有線(xiàn)上環(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)有索引
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í),在沒(méi)有 where 條件或者where 后不是索引字段時(shí),必須使用 limit ;在有 where 條件時(shí),為索引字段

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

考慮到開(kāi)發(fā)人員有時(shí)候不小心誤更新數(shù)據(jù),要求線(xiàn)上庫(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ō)明是不支持子查詢(xún)的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ì)腳本之家的支持。  

相關(guān)文章

  • windows下安裝mysql8.0.18的教程(社區(qū)版)

    windows下安裝mysql8.0.18的教程(社區(qū)版)

    本文章簡(jiǎn)單介紹一下mysql在windows下的安裝方式,主要介紹了mysql社區(qū)版8.0.18版本,本文給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2020-01-01
  • 關(guān)于MySql的kill命令詳解

    關(guān)于MySql的kill命令詳解

    這篇文章主要介紹了關(guān)于MySql的kill命令詳解,不知道你在使用 MySQL 的時(shí)候,有沒(méi)有遇到過(guò)這樣的現(xiàn)象:使用了 kill 命令,卻沒(méi)能斷開(kāi)這個(gè)連接,今天我們就來(lái)講一講這個(gè)問(wèn)題,需要的朋友可以參考下
    2023-05-05
  • mysql中的各種約束條件深入探討

    mysql中的各種約束條件深入探討

    在mysql中對(duì)編輯的數(shù)據(jù)進(jìn)行類(lèi)型的限制,不滿(mǎn)足約束條件的報(bào)錯(cuò),本文給大家分享mysql中的各種約束條件,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2024-05-05
  • 全面講解MySQL子查詢(xún)

    全面講解MySQL子查詢(xún)

    子查詢(xún)就是將一個(gè)查詢(xún)結(jié)果作為判斷條件或者作為一張?zhí)摂M表在這個(gè)結(jié)果的基礎(chǔ)上進(jìn)行另一個(gè)查詢(xún),本文就詳細(xì)的介紹了MySQL子查詢(xún) ,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • MySQL?優(yōu)化?index?merge引起的死鎖分析

    MySQL?優(yōu)化?index?merge引起的死鎖分析

    這篇文章主要介紹了MySQL?優(yōu)化?index?merge引起的死鎖分析,MySQL通過(guò)優(yōu)化索引合并是遇到的死鎖問(wèn)題,下面具體分析需要的小伙伴可以參考一下
    2022-04-04
  • mysql 8.0.24 安裝配置方法圖文教程

    mysql 8.0.24 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.24 安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • 解決MySQL因不能創(chuàng)建臨時(shí)文件而導(dǎo)致無(wú)法啟動(dòng)的方法

    解決MySQL因不能創(chuàng)建臨時(shí)文件而導(dǎo)致無(wú)法啟動(dòng)的方法

    這篇文章主要跟大家介紹了關(guān)于解決MySQL因不能創(chuàng)建臨時(shí)文件而導(dǎo)致無(wú)法啟動(dòng)的方法,文中通過(guò)示例代碼介紹了詳細(xì)的解決方法,對(duì)大家具有一定的的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-06-06
  • MySQL復(fù)合查詢(xún)的實(shí)現(xiàn)示例

    MySQL復(fù)合查詢(xún)的實(shí)現(xiàn)示例

    復(fù)合查詢(xún)語(yǔ)句是MySQL中一種非常重要的查詢(xún)方式,可以用于優(yōu)化查詢(xún)性能和控制查詢(xún)的結(jié)果集,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-10-10
  • java連接mysql底層封裝詳解

    java連接mysql底層封裝詳解

    這篇文章主要介紹了java連接mysql底層封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • MySQL命令行刪除表中的一個(gè)字段

    MySQL命令行刪除表中的一個(gè)字段

    本文介紹在MySQL數(shù)據(jù)庫(kù)中,如何根據(jù)字段名來(lái)刪除表中的一個(gè)字段,需要的朋友可以參考下
    2016-04-04

最新評(píng)論