mysql模式Strict Mode

http://www.dangkai.com/ArticlePage/Article8660.htm

MySQL模式 : StrictMode

I. Strict Mode阐述
根据 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES) 的限制:

1).不支持对not null字段插入null值
2).不支持对自增长字段插入''值,可插入null值
3).不支持 text 字段有默认值

看下面代码:(第一个字段为自增字段)
Sql代码 复制代码
  1. $query="insert intodemovalues('','$firstname','$lastname','$sex')";  

上边代码只在非 strict模式有效。

Code代码 复制代码
  1. $query="insert intodemovalues(NULL,'$firstname','$lastname','$sex')";  

上边代码只在 strict模式有效。把空值''换成了NULL.

II.让数据库支持StrictMode

1.对数据库结构进行以下改进来支持strictmode:
1) 给所有not null字段都设置非null默认值,字符串默认值为 '',数值默认值为 0,日期默认值为 '0000-00-0000:00:00'
2) 去掉text字段的默认值
3) 规范化改进: 把 title 字段统一改为 varchar(255),把有默认值的null字段改为notnull字段

2.如果安装的PHP程序数据库结构关闭Strictmode
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 =''");


*****************************************************************************************************************************************************************************
http://technoboy.iteye.com/blog/1004905

1. sql_mode模式
  mysql数据库的中有一个环境变量sql_mode,定义了mysql应该支持的sql语法,数据校验等!我们可以通过以下方式查看当前数据库使用的sql_mode:
mysql> select @@sql_mode;

mysql5.0以上版本支持三种sql_mode模式:ANSI、TRADITIONAL和STRICT_TRANS_TABLES。

ANSI模式:宽松模式,对插入数据进行校验,如果不符合定义类型或长度,对数据类型调整或截断保存,报warning警告。

TRADITIONAL模式:严格模式,当向mysql数据库插入数据时,进行数据的严格校验,保证错误数据不能插入,报error错误。用于事物时,会进行事物的回滚。

STRICT_TRANS_TABLES模式:严格模式,进行数据的严格校验,错误数据不能插入,报error错误



看一下TRADITIONAL模式,我们发现在TRADITIONAL模式下,对所有的事务存储引擎,非事务存储引擎检查,日期类型中的月和日部分不能包含0,不能有0这样的日期(0000-00-00),数据不能除0,禁止grant自动创建新用户等一些校验。

注意:我们这里设置的sql_mode都是session级别的。另外,可以直接修改my.ini文件,找到sql_mode,然后设置新的模式即可

你可能感兴趣的:(mysql)