MySQL模式 Strict Mode知識點詳解
I. Strict Mode闡述
根據 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES) 的限制:
1).不支持對not null字段插入null值
2).不支持對自增長字段插入’’值,可插入null值
3).不支持 text 字段有默認值
看下面代碼:(第一個字段為自增字段)
Sql代碼
$query='insert into demo values(’’,’$firstname’,’$lastname’,’$sex’)';
上邊代碼只在非strict模式有效。
Code代碼
$query='insert into demo values(NULL,’$firstname’,’$lastname’,’$sex’)';
上邊代碼只在strict模式有效。把空值’’換成了NULL.
II.讓數據庫支持Strict Mode
1.對數據庫結構進行以下改進來支持strict mode:
1) 給所有not null字段都設置非null默認值,字符串默認值為 ’’,數值默認值為 0,日期默認值為 ’0000-00-00 00:00:00’
2) 去掉text字段的默認值
3) 規范化改進: 把 title 字段統一改為 varchar(255),把有默認值的null字段改為not null字段
2.如果安裝的PHP程序數據庫結構關閉Strict mode
1).一個是安裝mysql5.0(含以上)版本的時候去掉strict mode。
編輯 my.cnf,關閉Strict Mode:
sql-mode='NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
2). 另一個就是修改查詢語句。例如在
if ($this->dbcharset) {@mysql_query('SET NAMES '.$this->dbcharset);}
后面執行
mysql_query('SET @@sql_mode = ’’');
注意確定你使用的是MySQL5
mysqli方式類似,就是執行的是
mysqli_query($this->connection_id, 'SET @@sql_mode = ’’');
到此這篇關于MySQL模式 Strict Mode知識點詳解的文章就介紹到這了,更多相關MySQL模式 Strict Mode內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
1. 恢復從 Access 2000、 Access 2002 或 Access 2003 中數據庫刪除表的方法2. Mysql入門系列:建立MYSQL客戶機程序的一般過程3. 啟動MYSQL出錯 Manager of pid-file quit without updating file.4. Microsoft Office Access修改代碼字體大小的方法5. MySQL中InnoDB和MyISAM類型的差別6. MySQL 8.0 之索引跳躍掃描(Index Skip Scan)7. MySQL 字符串函數:字符串截取8. Mysql入門系列:MYSQL創建、刪除、索引和更改表9. ACCESS轉SQL數據庫相關的幾個技能10. mysql數據存放的位置在哪
