博客
关于我
MySQL sql_mode=only_full_group_by问题解决办法
阅读量:798 次
发布时间:2023-02-10

本文共 1124 字,大约阅读时间需要 3 分钟。

在服务器数据库查询中使用了GROUP BY语句,结果却报出了以下错误:

1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'csc_risk.a.DefaultDate' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by, Time: 0.035000s

于是,将部分数据迁移到本地进行测试。发现SQL语句可以正常执行,并查看了数据库版本。

原因分析:

MySQL 5.7版本默认设置了mysql sql_mode = only_full_group_by属性,导致报错。

验证数据版本:

为了确认是否是数据版本问题,查询版本信息:

SELECT VERSION()

结果显示数据库版本为5.7.24。

解决方法:

了解到原因后,解决方案如下:

  • 查看当前SQL模式:

    查询SQL模式设置:

    SELECT @@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模式:

    为避免再次出现类似问题,可以通过以下命令关闭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';

    请注意:上述命令会修改全局SQL模式设置,对于新建的数据库有效。如果是已有数据库,则需要在对应数据库中执行类似操作:

    SET sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
  • 通过上述步骤,可以解决GROUP BY语句在MySQL 5.7版本下的兼容性问题。

    转载地址:http://orffk.baihongyu.com/

    你可能感兴趣的文章
    MYSQL sql语句针对数据记录时间范围查询的效率对比
    查看>>
    mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
    查看>>
    mysql sysbench测试安装及命令
    查看>>
    mysql Timestamp时间隔了8小时
    查看>>
    Mysql tinyint(1)与tinyint(4)的区别
    查看>>
    MySQL Troubleshoting:Waiting on query cache mutex
    查看>>
    mysql union orderby 无效
    查看>>
    mysql v$session_Oracle 进程查看v$session
    查看>>
    mysql where中如何判断不为空
    查看>>
    mysql where中如何判断不为空
    查看>>
    MySQL Workbench 使用手册:从入门到精通
    查看>>
    MySQL Workbench 数据库建模详解:从设计到实践
    查看>>
    MySQL Workbench 数据建模全解析:从基础到实践
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>