您好,登錄后才能下訂單哦!
這篇“MySQL 5.7之SQL_MODE怎么設置”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“MySQL 5.7之SQL_MODE怎么設置”文章吧。
sql_mode是個容易被忽視的變量,在5.5默認值是空值,在這種設置下是可以允許一些非法操作的,比如允許一些非法數據的插入。
在5.6中強化了該值設置,5.7中更注重了安全規范性,這個值默認為嚴格模式
通過設置sql mode,可以完成不同嚴格程度的數據校驗,有效保障數據準備性。
通過設置sql mode 為寬松模式,來保證大多數sql符合標準的sql語法,這樣應用在不同數據庫之間進行遷移時,則不需要對業務sql進行較大的修改,可以很方便的遷移到目標數據庫中。
ONLY_FULL_GROUP_BY
對于使用 GROUP BY 進行查詢的SQL,不允許 SELECT 部分出現 GROUP BY 中未出現的字段,也就是 SELECT 查詢的字段必須是 GROUP BY 中出現的或者使用聚合函數的或者是具有唯一屬性的。
create table test(name varchar(10),value int); insert into test values ('a',1),('a',20),('b',23),('c',15),('c',30); #默認情況是可能會寫出無意義或錯誤的聚合語句: SET sql_mode=''; select * from test group by name; select value,sum(value) from test group by name; # 使用該模式后,寫法必須標準 SET sql_mode='ONLY_FULL_GROUP_BY'; select name,sum(value) from test group by name; -- 錯誤寫法則報錯 select value,sum(value) from test group by name; # 報錯終止 ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'test.test.value' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
STRICT_TRANS_TABLES
該選項針對事務性存儲引擎生效,對于非事務性存儲引擎無效,該選項表示開啟strict sql模式。在strict sql模式下,在INSERT或者UPDATE語句中,插入或者更新了某個不符合規定的字段值,則會直接報錯中斷操作
create table test(value int(1)); SET sql_mode=''; #默認只要第一個值 insert into test(value) values('a'),(1); #不報錯 insert into test(value) values(2),('a'); #不報錯 select * from test; +------------+ | value | +------------+ | 0 | | 1 | | 2 | | 0 | +------------+ #后面刪除表不再說明! drop table test; create table test(value int(1)); SET sql_mode='STRICT_TRANS_TABLES'; #每個值都判斷 insert into test(value) values('a'),(1); #報錯,第一行'a'錯誤。 ERROR 1366 (HY000): Incorrect integer value: 'a' for column 'value' at row 1
NO_ZERO_IN_DATE
MySQL中插入的時間字段值,不允許日期和月份為零
create table test(value date); SET sql_mode=''; insert into test(value) values('2020-00-00'); #結果為 '2020-00-00' SET sql_mode='NO_ZERO_IN_DATE'; insert into test(value) values('2021-00-00'); #不符合,轉為 '0000-00-00'
NO_ZERO_DATE
MySQL中插入的時間字段值,不允許插入 ‘0000-00-00’ 日期
create table test(value date); SET sql_mode=''; insert into test(value) values('0000-00-00'); #無警告 warning SET sql_mode='STRICT_TRANS_TABLES'; insert into test(value) values('0000-00-00'); #無警告 warning SET sql_mode='NO_ZERO_DATE'; insert into test(value) values('0000-00-00'); #有警告 warning SET sql_mode='NO_ZERO_DATE,STRICT_TRANS_TABLES' insert into test(value) values('0000-00-00'); # 報錯終止 ERROR 1292 (22007): Incorrect date value: '0000-00-00' for column 'value' at row 1
ERROR_FOR_DIVISION_BY_ZERO
INSERT或者UPDATE語句中,如果數據被0除,則出現警告(非strict sql模式下)或者錯誤(strict sql模式下)。
當該選項關閉時,數字被0除,得到NULL且不會產生警告
當該選項開啟且處于非strict sql模式下,數字被0除,得到NULL但是會產生警告
當該選項開啟且處于strict sql模式下,數字被0除,產生錯誤且中斷操作
create table test(value int); SET sql_mode=''; select 10/0; #無警告 warning insert into test(value) values(10/0); #無警告 warning SET sql_mode='STRICT_TRANS_TABLES'; select 10/0; #無警告 warning insert into test(value) values(10/0); #無警告 warning SET sql_mode='ERROR_FOR_DIVISION_BY_ZERO'; select 10/0; #有警告 warning insert into test(value) values(10/0); #有警告 warning SET sql_mode='ERROR_FOR_DIVISION_BY_ZERO,STRICT_TRANS_TABLES'; select 10/0; #有警告 warning insert into test(value) values(10/0); #報錯:ERROR 1365 (22012): Division by 0
NO_AUTO_CREATE_USER
禁止GRANT創建密碼為空的用戶
SET sql_mode=''; grant all on test.* to test01@'localhost'; #不報錯(無需要設置密碼) SET sql_mode='NO_AUTO_CREATE_USER'; # 報錯 ERROR 1133 (42000): Can't find any matching row in the user table #正確 寫法,需要設置密碼 grant all on test.* to test01@'localhost' identified by 'test01...';
NO_ENGINE_SUBSTITUTION
在使用CREATE TABLE或者ALTER TABLE語法執行存儲引擎的時候,如果設定的存儲引擎被禁用或者未編譯,會產生錯誤。
# 查看當前支持的存儲引擎 show engines; set sql_mode=''; create table test(id int) ENGINE="test"; Query OK, 0 rows affected, 2 warnings (0.03 sec) select table_name,engine from information_schema.tables where table_schema='test' and table_name='test'; # 轉為默認存儲引擎 +------------+--------+ | table_name | engine | +------------+--------+ | test | InnoDB | +------------+--------+ SET sql_mode='NO_ENGINE_SUBSTITUTION'; create table test(id int) ENGINE=test; # 報錯 ERROR 1286 (42000): Unknown storage engine 'test'
方式一: 這是一個可修改全局變量
> show variables like '%sql_mode%'; > set @@sql_mode="NO_ENGINE_SUBSTITUTION" > set session sql_mode='STRICT_TRANS_TABLES';
方式二: 通過修改配置文件(需要重啟生效)
# vim /etc/my.cnf [mysqld] ...... sql_mode="NO_ENGINE_SUBSTITUTION" ......
以上就是關于“MySQL 5.7之SQL_MODE怎么設置”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。