文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mysql8 “this is incompatible with sql_mode=only_full_group_by“的解决办法。

2023-09-04 09:54

关注

参考:https://blog.csdn.net/u012660464/article/details/113977173

一、报错问题

1055 - Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column '字段名' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

大致意思:

SELECT列表的表达式#2不在GROUP BY子句中,并且包含非聚合列的jsfwpt.o。它在功能上不依赖于GROUP BY子句中的列;这与sql_mode=only_full_group_by不兼容

二、导致的原因

三、检查是否是此原因

查看sql_mode

select @@GLOBAL.sql_mode;

执行结果:sql_mode开启了only_full_group_by 属性
在这里插入图片描述

四、解决办法

方法1、使用函数ANY_VALUE()

使用ANY_VALUE(<字段名>)将报错的字段包裹起来

MySQL有any_value(field)函数,它主要的作用就是抑制ONLY_FULL_GROUP_BY值被拒绝。
这样sql语句不管是在ONLY_FULL_GROUP_BY模式关闭状态还是在开启模式都可以正常执行,不被mysql拒绝。

方法2、临时修改sql_mode

方法2:仅用于临时去掉ONLY_FULL_GROUP_BY,重新设置值,重启mysql之后此方法就会失效

方法3、永久修改sql_mode

通过修改mysql配置文件my.ini解决

1、windows系统MySQL8永久修改sql_mode的方式

在MySQL安装的目录所在的分区根目录下,“查看“——勾选显示“隐藏的项目”,
2、my.ini的路径:ProgramData\MySQL\MySQL Server 8.0
在这里插入图片描述
3、打开my.ini文件
在[mysqld]下面找sql-mode,修改为如下内容:(没有sql-mode就追加在[mysqld]下面)

sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"

在这里插入图片描述
4、重启mysql
在这里插入图片描述

2、liunx上的修改方式

文件路径一般在:/etc/my.cnf,/etc/mysql/my.cnf
2、my.ini的具体修改方法略:与windows上一样

五、验证

在这里插入图片描述
sql_mode已经没有only_full_group_by 属性了

来源地址:https://blog.csdn.net/qq_43427354/article/details/128462293

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯