zoukankan      html  css  js  c++  java
  • 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:

    到此已经成功解决了这个问题。

    原文地址:https://www.cnblogs.com/52lnamp/p/9294330.html
  • 相关阅读:
    CSS浏览器兼容解决总结
    Access的数据操作类(带异常处理)
    网页消息类
    生成验证码(纯中文)
    C#连接各种数据库(持续更新中)
    asp.net中实现文件批量上传!你会了吗?
    http 错误编号大全(转)
    SQL SERVER数据操作类
    web.config加密和解密
    C#中操作CMD命令行窗口
  • 原文地址:https://www.cnblogs.com/jpfss/p/11125769.html
Copyright © 2011-2022 走看看