MySQL sql_mode=only_full_group_by错误
今天在测试服务器上突然出现了这么一个MySQL的问题,同样的代码正式服没有问题,那肯定就是出在了配置上,查了一下原因才明白原来是数据库版本为5.7以上的版本,
默认是开启了 only_full_group_by
模式的,但开启这个模式后,原先的 group by
语句就报错,
查询MySQL版本可以在命令行模式刚连接上数据库时就能看到,或者在进入mysql后使用命令:status查看版本号,
既然是版本的问题,那就查询一下配置看看具体的情况,命令行连接上数据库,再输入命令:
select @@sql_mode;
你会看到sql_mode的配置情况:
其中ONLY_FULL_GROUP_BY就是造成这个错误的罪魁祸首了,
对于group by聚合操作,如果在select中的列没有在group by中出现,那么这个SQL是不合法的,因为列不在group by从句中,所以设置了sql_mode=only_full_group_by的数据库,在使用group by时就会报错,
既然知道了问题,那么修改这个配置就可以了,找到MySQL的配置文件,在linux系统上/etc/my.cnf文件,查询sql_mode字段,我并没有在配置文件中找到这个关键字,所以我手动添加进去:
sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
需要注意的一点是一定要添加在[mysqld]配置内,这样添加完后重启mysql才会生效,退出数据库:exit,重启命令:
service mysqld restart;
刷新页面报错信息消失成功解决,再次连续上数据库查看sql_mode配置select @@sql_mode:
到此已经成功解决了这个问题。
上一篇: 年过的开心不?看笑段就知道了
下一篇: 夫妻都是笑林鸟,可笑惨了!
推荐阅读
-
mysql数据库中1045错误的解决方法
-
MySql 安装时的1045错误
-
MySQL server has gone away错误提示解决方法
-
CodeIgniter错误mysql_connect(): No such file or directory解决方法
-
Mysql主从数据库(Master/Slave)同步配置与常见错误
-
phpMyAdmin链接MySql错误 个人解决方案
-
SQLyog连接MySQL8.0报2058错误的解决方案
-
MySql插入数据成功但是报[Err] 1055错误的解决方案
-
解决修改mysql的data_dir所引发的错误问题
-
阿里云安装mysql数据库出现2002错误解决办法