• MySQL提示sql_mode=only_full_group_by解决办法


    MySQL异常sql_mode=only_full_group_by

    原因:在MySQL 5.7后MySQL默认开启了SQL_MODE严格模式,对数据进行严格校验。
    会报sql_mode=only_full_group_by错误说明写的SQL语句不严谨,
    对于group by聚合操作,select中的列只能是出现在group by中的列,使用聚合函数除外,如max()、min()等

    如以下例子会报错:

    select id, no, uid from user_order group by uid;

    改成下面的SQL则不报错:

    select uid from user_order group by uid;


    解决这个问题可以有三个方法:

    方法一:
    使用 group_concat() 或 any_value()
    group_concat():将分到同一组的数据默认用逗号隔开作为返回数据
    any_value():将分到同一组的数据里第一条数据的指定列值作为返回数据

    修改后语句如下:

    1. select GROUP_CONCAT(id), GROUP_CONCAT(no), uid from user_order group by uid;
    2. select any_value(id), any_value(no), uid from user_order group by uid;


    方法二:
    如果语句太多,变动太大,可以改数据库配置

    首先查看当前sql_mode

    select @@global.sql_mode;

    可以看到返回以下值:

    ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

    重新设置,去掉ONLY_FULL_GROUP_BY即可:

    SET GLOBAL sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

    当然,如果想去掉所有限制也是可以的:

    SET GLOBAL sql_mode='';

    这个方法的好处是不用重启MySQL生效(需要注意的是在当前会话实例中是不生效的),坏处是重启后会恢复原样。


    方法三:
    永久生效,修改配置文件my.ini

    在[mysqld]模块下新增一行配置:

    sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'

    保存,重启后生效。

  • 相关阅读:
    fdbus之CBaseClient类和CBaseServer类
    hive拼接字符串concat函数的用法
    tomcat
    企业做商城怎么选品
    Unity 最近经验分享
    web前端期末大作业(我的家乡广安网页设计与制作)HTML+CSS网页设计实例 企业网站制作
    力扣203 - 移除链表元素【LeetCode转VS调试技巧教学】
    C语言实现分块查找
    每日一面系列之volatile 的理解
    【Excel中阶技巧】表结构、函数、数据验证、导入导出、透视表、Power Pivot、其他技巧
  • 原文地址:https://blog.csdn.net/M__L__/article/details/126806559