严格模式是指 STRICT_ALL_TABLES和 STRICT_TRANS_TABLES么
全局修改,需要重启mysql生效,下次重启仍然生效
mysql配置文件[mysqld]下
# Set the SQL mode to strictsql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER...."
运行时修改,不需要重启即能生效,重启后该修改不生效,取配置文件
SET GLOBAL sql_mode = 'mode1,mode2...' #数据库没有重启,新进连接都有效SET SESSION sql_mode = 'mode1,mode2...' #数据库没有重启,当前连接有效
或者用命令行启动mysql加上 --sql-mode="mode1,mode2..."参数,同set global
最后检查下模式是不是改过来了:
select @@global.sql_mode global_mode,@@sql_mode session_mode是php的,是判断获得的版本号如果大于‘5.0.1’就执行mysql_query()方法,mysql_query() 向与指定的连接标识符关联的服务器中的当前活动数据库发送一条查询。如果没有指定 link_identifier,则使用上一个打开的连接。如果没有打开的连接,本函数会尝试无参数调用 mysql_connect() 函数来建立一个连接并使用之。查询结果会被缓存。
1.用sql工具执行show variables like‘%sql_mode%’
2.如果重启之后不成功, 注意检查你的my.ini 或者 my.cnf 有没改对,是不是有多个同名字的配置文件, 也有可能叫sql-mode 或sql_mode 注意中间的‘-’ 或 ‘_’
mysql的sql_mode合理设置,sql_mode是个很容易被忽视的变量,默认值是空值,在这种设置下是可以允许一些非法 *** 作的,比如允许一些非法数据的插入。在生产环境必须将这个值设置为严格模式,所以开发、测试环境的数据库也必须要设置,这样在开发测试阶段就可以发现问题 。
ONLY_FULL_GROUP_BY,对于GROUP BY聚合 *** 作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中
NO_AUTO_VALUE_ON_ZERO,该值影响自增长列的插入。默认设置下,插入0或NULL代表生成下一个自增长值。如果用户希望插入的值为0,而该列又是自增长的,那么这个选项就有用了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)