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

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

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

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

这个就是错误截图

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

出现原因: MySQL的版本问题

MySQL 5.7.5以上版本,实现了对功能依赖的检测。如果启用了only_full_group_by SQL模式(默认启用),那么MySQL就会拒绝执行 select list、HAVING condition或ORDER BY list引用既不在GROUP BY子句中被命名,也不在功能上依赖于GROUP BY列(由GROUP BY列唯一确定)的未聚合列的查询。

从MySQL5.7.5开始,默认的SQL模式包括only_full_group_by。(在5.7.5之前,MySQL没有检测到功能依赖项,only_full_group_by在默认情况下是不启用的。关于前5.7.5行为的描述,请参阅MySQL 5.6参考手册。)
 

解决办法:两种

第一种:修改MySQL的配置文件

1. 连接数据库 输入下面命令,查询sql的模式

select @@sql_mode;

2. 修改数据库配置my.ini文件

在你安装数据库的文件夹下的my.ini文件

增加一行代码:

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

3. 重启MySQL服务

备注:我个人觉得最好不用这样吧 因为项目可能其他地方或许用到了这种模式,最好的方法是不要改动mysql的配置。正所谓能跑起来就不要动他的原理!

第二种方法:修改自己的sql

每个字段前加上any_value()  这种方法比较好  只需要修改sql 不会影响到其他问题

修改前:

SELECT
	id AS a,
	name  AS  b,
    age AS c
FROM
	user

修改后:

SELECT
	any_value(id)AS a,
	any_value(name)AS  b,
    any_value(age)AS c
FROM
	user

总结

到此这篇关于MySQL出现this is incompatible with sql_mode=only_full_group_by错误的解决办法的文章就介绍到这了,更多相关this is incompatible with sql_mode=only_full_group_by内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

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

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

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

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

下载Word文档

猜你喜欢

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

Python 出现错误TypeError: ‘NoneType’ object is not iterable解决办法

Python 出现错误TypeError: ‘NoneType' object is not iterable解决办法 TypeError: 'NoneType' object is not iterable 这个错误提示一般发生在将No
2022-06-04

Docker 安装MySQL出现:The designated data directory /var/lib/mysql/ is unusable.错误解决办法

[MY-010457]、 [MY-013236]错误 Docker安装MySqL初始化错误解决办法错误出现创建语句分析查找问题分析问题 --initialize --lower-case-table-names=1 惹的祸不同系统,
2023-08-16

Redis 出现错误1067的解决办法

Redis 出现错误1067的解决办法 一、问题描述:在Windows启动Redis服务时,发生如下错误:Windows无法启动Redis服务(位于本地计算机上)。 错误1067:进程意外终止。在Windows CMD命令行启动时提示:D
2022-06-04

Word文档出现normal.dotm错误的解决办法

当Word文档出现normal.dotm错误时,可以尝试以下解决办法:1. 关闭所有打开的Word文档和Word程序。2. 搜索计算机上的normal.dotm文件。在Windows操作系统中,normal.dotm文件通常位于以下路径之一
2023-09-17

使用python中出现的错误及解决办法

【问题1】在编译安装完Python后,不能正常使用yum,使用yum出现以下错误[root@localhost bin]# yum  File "/usr/bin/yum", line 30    except KeyboardInterr
2023-01-31

MySQL查询出现1055错误的解决方法

当SQL语句查询报1055错误时的解决方法 报错内容如下 报错原因 1.SQL语句中使用了group by,并且不需要分组的字段没有加上any_value()函数 2.MySQL数据库版本是大于5.7,报错信息中最后有一句sql_mode
2023-08-16

编程热搜

目录