MySQL模式 : Strict Mode

本文介绍了MySQL 5.0及以上版本中Strict Mode的功能和限制,并提供了如何让数据库支持Strict Mode的方法,包括对数据库结构的改进措施及如何在PHP程序中关闭Strict Mode。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[color=darkred][size=medium]I. Strict Mode阐述[/size][/color]
根据 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES) 的限制:

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

看下面代码:(第一个字段为自增字段)
$query="insert into demo values('','$firstname','$lastname','$sex')";

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

$query="insert into demo values(NULL,'$firstname','$lastname','$sex')";

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

[color=darkred][size=medium]II.让数据库支持Strict Mode[/size][/color]

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

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

[color=red]注意确定你使用的是MySQL5[/color]

mysqli方式类似,就是执行的是
mysqli_query($this->connection_id, "SET @@sql_mode = ''");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值