Mysql之SQL Mode用法詳解
一、Mysql SQL Mode簡介
通常來說MySQL服務(wù)器能夠工作在不同的SQL模式下,并能針對不同的客戶端以不同的方式應(yīng)用這些模式。這樣,應(yīng)用程序就能對服務(wù)器操作進行量身定制以滿足自己的需求。這類模式定義了MySQL應(yīng)支持的SQL語法,以及應(yīng)該在數(shù)據(jù)上執(zhí)行何種確認檢查。這樣,就能在眾多不同的環(huán)境下、與其他數(shù)據(jù)庫服務(wù)器一起更容易地使用MySQL??梢允褂谩?-sql-mode="modes"”選項,通過啟動mysqld來設(shè)置默認的SQL模式。而從MySQL 4.1開始,也能在啟動之后,使用SET [SESSION|GLOBAL] sql_mode='modes'語句,通過設(shè)置sql_mode變量更改其模式。
通常在linux下安裝完mysql后,其默認的sql-mode值是空,在這種情形下mysql執(zhí)行的是一種不嚴格的檢查,例如日期字段可以插入'0000-00-00 00:00:00'這樣的值,還有如果要插入的字段長度超過列定義的長度,那么mysql不會終止操作,而是會自動截斷后面的字符繼續(xù)插入操作,如下例:
mysql> create table t5 (c1 char(3));
mysql> insert into t5 values('abcd');
mysql> select * from t5;
+------+
| c1 |
+------+
| abc |
+------+
1 row in set (0.00 sec)
我們發(fā)現(xiàn)插入的字符被自動截斷了,但是如果我們本意希望如果長度超過限制就報錯,那么我們可以設(shè)置sql_mode為STRICT_TRANS_TABLES,如下:
mysql> set session sql_mode='STRICT_TRANS_TABLES'
這樣我們再執(zhí)行同樣的操作,mysql就會告訴我們插入的值太長,操作被終止,如下:
mysql> insert into t5 values('abcd');
ERROR 1406 (22001): Data too long for column 'c1' at row 1
經(jīng)常使用的sql_mode值:
Sql_mode值
描述
ANSI
更改語法和行為,使其更符合標準SQL。
STRICT_TRANS_TABLES
如果不能將給定的值插入到事務(wù)表中,則放棄該語句。對于非事務(wù)表,如果值出現(xiàn)在單行語句或多行語句的第1行,則放棄該語句。本節(jié)后面給出了更詳細的描述。
TRADITIONAL
Make MySQL的行為象“傳統(tǒng)”SQL數(shù)據(jù)庫系統(tǒng)。該模式的簡單描述是當在列中插入不正確的值時“給出錯誤而不是警告”。注釋:一旦發(fā)現(xiàn)錯誤立即放棄INSERT/UPDATE。如果你使用非事務(wù)存儲引擎,這種方式不是你想要的,因為出現(xiàn)錯誤前進行的數(shù)據(jù)更改不會“滾動”,結(jié)果是更新“只進行了一部分”。
說明:如果把sql_mode的值設(shè)置成后面的兩個值(也就是我們說的嚴格模式),那么當在列中插入或更新不正確的值時,mysql將會給出錯誤,并且放棄insert/update操作。在我們的一般應(yīng)用中建議使用這兩種模式,而不是使用默認的空或ANSI模式。但是需要注意的問題是,如果數(shù)據(jù)庫運行在嚴格模式下,并且你的存儲引擎不支持事務(wù),那么有數(shù)據(jù)不一致的風險存在,比如一組sql中有兩個dml語句,如果后面的一個出現(xiàn)了問題,但是前面的已經(jīng)操作成功,那么mysql并不能回滾前面的操作。因此說設(shè)置sql_mode需要應(yīng)用人員權(quán)衡各種得失,從而得到一個合適的選擇。
Sql_mode的值還有很多,這里不再累述,可以參考相關(guān)的手冊。
二、SQL Mode與可移植性
如果mysql與其它異構(gòu)數(shù)據(jù)庫之間有數(shù)據(jù)移植的需求的話,那么下面的sql_mode的組合設(shè)置可以達到相應(yīng)的效果:
| 數(shù)據(jù)庫 | Sql_mode值 |
|---|---|
| DB2 | PIPES_AS_CONCAT、ANSI_QUOTES、IGNORE_SPACE、NO_KEY_OPTIONS、NO_TABLE_OPTIONS、NO_FIELD_OPTIONS |
| MAXDB | PIPES_AS_CONCAT、ANSI_QUOTES、IGNORE_SPACE、NO_KEY_OPTIONS、NO_TABLE_OPTIONS、NO_FIELD_OPTIONS、 NO_AUTO_CREATE_USER |
| MSSQL | PIPES_AS_CONCAT、ANSI_QUOTES、IGNORE_SPACE、NO_KEY_OPTIONS、NO_TABLE_OPTIONS、 NO_FIELD_OPTIONS |
| ORACLE | PIPES_AS_CONCAT、ANSI_QUOTES、IGNORE_SPACE、NO_KEY_OPTIONS、NO_TABLE_OPTIONS、NO_FIELD_OPTIONS、NO_AUTO_CREATE_USER |
| POSTGRESQL | PIPES_AS_CONCAT、ANSI_QUOTES、IGNORE_SPACE、NO_KEY_OPTIONS、NO_TABLE_OPTIONS、NO_FIELD_OPTIONS |
三、SQL Mode與數(shù)據(jù)效驗
SQL Mode 還可以實現(xiàn)對數(shù)據(jù)效驗和轉(zhuǎn)移等功能如:
1.效驗日期數(shù)據(jù)合法性.
2.在INSERT或UPDATE過程中,如果被零除(或MOD(X,0)),則產(chǎn)生錯誤
3.將‘"'視為識別符引號(‘`'引號字符)
4.禁用反斜線字符(‘\')做為字符串內(nèi)的退出字符。啟用NO_BACKSLASH_ESCAPES模式,反斜線則成為普通字符。
5.將||視為字符串連接操作符(+)(同CONCAT()),而不視為OR。
相關(guān)文章
一文總結(jié)MySQL中數(shù)學(xué)函數(shù)有哪些
MySQL函數(shù)包括數(shù)學(xué)函數(shù)、字符串函數(shù)、日期和時間函數(shù)、條件判斷函數(shù)、系統(tǒng)信息函數(shù)、加密函數(shù)等,下面這篇文章主要給大家介紹了關(guān)于MySQL中數(shù)學(xué)函數(shù)有哪些的相關(guān)資料,需要的朋友可以參考下2023-02-02
MySql中如何使用 explain 查詢 SQL 的執(zhí)行計劃
explain命令是查看查詢優(yōu)化器如何決定執(zhí)行查詢的主要方法。這篇文章重點給大家介紹MySql中如何使用 explain 查詢 SQL 的執(zhí)行計劃,感興趣的朋友一起看看吧2018-05-05
MySQL數(shù)據(jù)庫備份恢復(fù)實現(xiàn)代碼
這篇文章主要介紹了MySQL數(shù)據(jù)庫備份恢復(fù)實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下2020-06-06
MySQL關(guān)聯(lián)查詢Join的實現(xiàn)原理和優(yōu)化建議
在平時的開發(fā)過程中,大家應(yīng)該經(jīng)常會用到j(luò)oin進行多個表的之間的關(guān)聯(lián)查詢,但是如果使用不合理的話,會導(dǎo)致查詢性能下降,本文就MySQL中的關(guān)聯(lián)查詢的實現(xiàn)原理以及一些優(yōu)化建議等內(nèi)容做一個講解,需要的朋友可以參考下2023-07-07
MySQL?SQL預(yù)處理(Prepared)的語法實例與注意事項
所謂預(yù)編譯語句就是將此類SQL語句中的值用占位符替代,可以視為將 SQL語句模板化或者說參數(shù)化,一般稱這類語句叫Prepared Statements,下面這篇文章主要給大家介紹了關(guān)于MySQL?SQL預(yù)處理(Prepared)的相關(guān)資料,需要的朋友可以參考下2022-01-01
Mysql中replace與replace into的用法講解
今天小編就為大家分享一篇關(guān)于Mysql中replace與replace into的用法講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03

