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,而该列又是自增长的,那么这个选项就有用了。
mysql启动报错:Starting mysqld (via systemctl): Job for mysqld.service failed because the control process exited with error code. See "systemctl status mysqld.service" and "journalctl -xe" for details.[FAILED]
编辑mysql配置文件
vi /etc/my.conf
最后一行加sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
source /etc/my.conf
再次启动
service myslqd start
细化解析在 ANSI 模式下运行MySQL你可以使用“--ansi”启动选项,要求MySQLd使用ANSI模式。
在ANSI模式下运行服务器与使用该选项启动它的效果一样(在一行上指定“--sql_mode”值):
--transaction-isolation=SERIALIZABLE
--sql-mode=REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,
IGNORE_SPACE
在MySQL4.1中,能够用下述两条语句实现相同的效果(在一行上指定“sql_mode”值):
SET GLOBAL TRANSACTION ISOLATION LEVEL SERIALIZABLE
SET GLOBAL sql_mode = 'REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,
IGNORE_SPACE'
在MySQL 4.1.1中,也能用下述语句设置sql_mode选项:
SET GLOBAL sql_mode='ansi'
在本例中,将sql_mode变量的值设置为与ANSI模式相关的所有选项。你可以检查其结果,如下所示:
mysql>SET GLOBAL sql_mode='ansi'
mysql>SELECT @@global.sql_mode
->'REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,
IGNORE_SPACE,ANSI'
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)