我的编程空间,编程开发者的网络收藏夹
学习永远不晚

this is incompatible with sql_mode=only_full_group_by解决方案

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

this is incompatible with sql_mode=only_full_group_by解决方案

MySQL查询时报错:this is incompatible with sql_mode=only_full_group_by

在这里插入图片描述

报错原因分析:
一、原理层面
这个错误发生在mysql 5.7.5 版本及以上版本会出现的问题:
mysql 5.7.5版本以上默认的sql配置是:sql_mode=“ONLY_FULL_GROUP_BY”,这个配置严格执行了"SQL92标准"。

二、sql层面
在sql执行时,出现该原因,简单来说就是:
由于开启了ONLY_FULL_GROUP_BY的设置,如果select 的字段不在 group by 中,
并且select 的字段未使用聚合函数(SUM,AVG,MAX,MIN等)的话,那么这条sql查询是被mysql认为非法的,会报错误

解决方法
网上搜的都是有三种方案,我记录一下我使用的方法

一般MySQL装好之后

进入到下面目录,会有default.my.cnf文件

cd /usr/local/mysql/support-files

如果有这个文件,就可以直接复制到桌面,更面名称:my.cnf,进行编辑

插入以下代码,保存之后重启mysql就好了。

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

不知道什么原因,我这边没有那个文件
在这里插入图片描述
但是这个问题不大,没有咋们就自己创建一个就好了。

 sudo vim /etc/my.cnf

然后还是插入以下代码:

[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

保存之后重启服务,就好了
在这里插入图片描述

macbook 上安装 mysql8.0.28版本,解决这个问题的时候,因为也是没有my.cnf文件,于是自己创建的my.cnf,插入上面的代码之后,启动就会一直失败,于是就删除掉了‘NO_AUTO_CREATE_USER’,再次启动就ok了,这是针对我个人解决的方法,如果有其他问题可以评论区留言,一直探讨,寻找解决方案

[mysqld]sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

来源地址:https://blog.csdn.net/weixin_43818327/article/details/125598187

免责声明:

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

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

this is incompatible with sql_mode=only_full_group_by解决方案

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Mysql8报错this is incompatible with sql_mode=only_full_group_by问题

MySQL8中“thisisincompatiblewithsql_mode=only_full_group_by”错误提示指在ONLY_FULL_GROUP_BY模式下,未对所有非聚合列进行分组。解决方法包括:修改sql_mode设置为兼容模式或调整查询,如对所有非聚合列分组或使用子查询隐式分组。
Mysql8报错this is incompatible with sql_mode=only_full_group_by问题
2024-04-02

mysql5.7 gruop by报错this is incompatible with sql_mode=only_full_group_by

解析:在mysql 工具 搜索或者插入数据时报下面错误:ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated
2019-12-03

MySQL出现this is incompatible with sql_mode=only_full_group_by错误的解决办法

目录这个就是错误截图出现原因: mysql的版本问题解决办法:两种第一种:修改MySQL的配置文件第二种方法:修改自己的sql总结这个就是错误截图出现原因: MySQL的版本问题MySQL 5.7.5以上版本,实现了对功能依赖的检测。如果
2023-02-17

MySQL出现this is incompatible with sql_mode=only_full_group_by错误的解决办法

mysql是高版本,当执行group by时,select的字段不属于group by的字段的话,sql语句就会报错,下面这篇文章主要给大家介绍了关于MySQL出现this is incompatible with sql_mode=only_full_group_by错误的解决办法,需要的朋友可以参考下
2023-02-17

mysql 8.0 找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案

目录解决方法一(不推荐):临时sql_mode设置解决方法二:修改mysql的默认配置文件my.ini(永久配置,推荐)sql_mode=only_full_groandroidup_by问题产生原因:MySQL 5.7.5及以上功能依赖检
mysql 8.0 找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
2024-08-18

urllib3出现NotImplementedError("Iteration over this class is unlikely to be threadsafe.")的解决方案

报错的原因urllib在迭代这个类时会出现错误的原因是这个类不能安全地在多线程环境中迭代。这是因为在多线程环境中迭代这个类可能会导致线程间的竞争条件。更换成其他实现可能也是一种解决方案。在add_data()和iterate()方法中使用了
urllib3出现NotImplementedError(
2024-02-28

编程热搜

目录