小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

MySQL模式:Strict Mode

 看見就非常 2014-07-31
剛剛在配置阿里云主機(jī)的環(huán)境:IIS7.5+PHP5.3+MySQL5.5

安裝Mysql過程中遇到Strict Mode的選項,特意料了解了一下,大致如下:

 

一. Strict Mode的描述:
根據(jù) mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES) 的限制:
     1).不支持對not null字段插入null值
     2).不支持對自增長字段插入''值,可插入null值
     3).不支持 text 字段有默認(rèn)值
eg:
1.看下面代碼:(第一個字段為自增字段)
    $query="insert into demo values('','$firstname','$lastname','$sex')";
上邊代碼只在非strict模式有效,如果是strict模式下就會出錯。

2.$query="insert into demo values(NULL,'$firstname','$lastname','$sex')";
   上邊代碼只在strict模式有效。把空值''換成了NULL.

二. 讓數(shù)據(jù)庫支持Strict Mode
 1.對數(shù)據(jù)庫結(jié)構(gòu)進(jìn)行以下改進(jìn)來支持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ù)庫結(jié)構(gòu)關(guān)閉Strict mode
1).一個是安裝mysql5.0(含以上)版本的時候去掉strict mode
編輯 my.ini,關(guān)閉Strict Mode:
sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

2). 另一個就是修改查詢語句。例如在
if ($this->dbcharset) {
   @mysql_query("SET NAMES ".$this->dbcharset);
}
后面執(zhí)行
mysql_query("SET @@sql_mode = ''");

注意確定你使用的是MySQL5 以上版本

mysqli方式類似,就是執(zhí)行的是
mysqli_query($this->connection_id, "SET @@sql_mode = ''");

 

 

如果安裝過程中選擇了Strict Mode,如何關(guān)閉呢?也專門找了下方法,我建議安裝時還是不要選擇了!

 

關(guān)閉MySQLstrict mode的具體做法:找到MySQL目錄下的my.ini,將其中的sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" 修改為sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION",重新啟動 Mysql服務(wù)

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多