• 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
  • 相关阅读:
    隐马尔科夫模型(HMM)
    各大IT企业招聘所须要求技能
    Java NIO和IO的主要差别
    Css 选择器总结
    程序猿生存定律-六个程序猿的故事(3)
    JVM学习心得
    APUE读书笔记-第14章-高级I/O
    《Word排版艺术》读后感,兼谈LaTeX
    LaTeX:Figures, Tables, and Equations 插入图表和公式
    LaTeX 的对参考文献的处理
  • 原文地址:https://www.cnblogs.com/jpfss/p/11125769.html
Copyright © 2020-2023  润新知