MySQL模式 Strict Mode知識(shí)點(diǎn)詳解
I. Strict Mode闡述
根據(jù) mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES) 的限制:
1).不支持對(duì)not null字段插入null值
2).不支持對(duì)自增長(zhǎng)字段插入’’值,可插入null值
3).不支持 text 字段有默認(rèn)值
看下面代碼:(第一個(gè)字段為自增字段)
Sql代碼
$query='insert into demo values(’’,’$firstname’,’$lastname’,’$sex’)';
上邊代碼只在非strict模式有效。
Code代碼
$query='insert into demo values(NULL,’$firstname’,’$lastname’,’$sex’)';
上邊代碼只在strict模式有效。把空值’’換成了NULL.
II.讓數(shù)據(jù)庫(kù)支持Strict Mode
1.對(duì)數(shù)據(jù)庫(kù)結(jié)構(gòu)進(jìn)行以下改進(jìn)來(lái)支持strict mode:
1) 給所有not null字段都設(shè)置非null默認(rèn)值,字符串默認(rèn)值為 ’’,數(shù)值默認(rèn)值為 0,日期默認(rèn)值為 ’0000-00-00 00:00:00’
2) 去掉text字段的默認(rèn)值
3) 規(guī)范化改進(jìn): 把 title 字段統(tǒng)一改為 varchar(255),把有默認(rèn)值的null字段改為not null字段
2.如果安裝的PHP程序數(shù)據(jù)庫(kù)結(jié)構(gòu)關(guān)閉Strict mode
1).一個(gè)是安裝mysql5.0(含以上)版本的時(shí)候去掉strict mode。
編輯 my.cnf,關(guān)閉Strict Mode:
sql-mode='NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
2). 另一個(gè)就是修改查詢語(yǔ)句。例如在
if ($this->dbcharset) {@mysql_query('SET NAMES '.$this->dbcharset);}
后面執(zhí)行
mysql_query('SET @@sql_mode = ’’');
注意確定你使用的是MySQL5
mysqli方式類(lèi)似,就是執(zhí)行的是
mysqli_query($this->connection_id, 'SET @@sql_mode = ’’');
到此這篇關(guān)于MySQL模式 Strict Mode知識(shí)點(diǎn)詳解的文章就介紹到這了,更多相關(guān)MySQL模式 Strict Mode內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. SQL Server 2005性能測(cè)試實(shí)踐-CPU篇 編譯與重編譯3. 關(guān)于Oracle中sqlldr的用法大全4. SQL Server 2008主要功能在兼容性上的問(wèn)題5. SQLite教程(二):C/C++接口簡(jiǎn)介6. 解決mybatis中的mapper命名問(wèn)題7. Mybatis Limit實(shí)現(xiàn)分頁(yè)功能8. 遠(yuǎn)程連接SQL Server 2000服務(wù)器的解決方案9. 安裝SQL Server 2005時(shí)出現(xiàn)計(jì)數(shù)器錯(cuò)誤10. 探討SQL Server 2005.NET CLR編程
