服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySQL出现this is incompatible with sql_mode=only_full_group_by错误的解决办法

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

2023-02-19 16:24Forever_jacklove Mysql

mysql是高版本,当执行group by时,select的字段不属于group by的字段的话,sql语句就会报错,下面这篇文章主要给大家介绍了关于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内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/Forever_jacklove/article/details/124731744

延伸 · 阅读

精彩推荐
  • MysqlCentOS7下mysql 8.0.16 安装配置方法图文教程

    CentOS7下mysql 8.0.16 安装配置方法图文教程

    这篇文章主要为大家详细介绍了CentOS7下mysql 8.0.16 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...

    TriumPhSK3642020-09-25
  • Mysql解决Windows环境下安装 mysql-8.0.11-winx64 遇到的问题

    解决Windows环境下安装 mysql-8.0.11-winx64 遇到的问题

    这篇文章主要介绍了Windows环境下安装 mysql-8.0.11-winx64 遇到的问题及解决办法 ,需要的朋友可以参考下...

    color_小浣熊5402019-06-18
  • Mysql常见php与mysql中文乱码问题解决办法

    常见php与mysql中文乱码问题解决办法

    MySQL对中文的支持程度还是很有限的,尤其是新手,但凡出现乱码问题,就会头大。 ...

    MYSQL教程网5752020-04-20
  • Mysql一文详解MySQL主从同步原理

    一文详解MySQL主从同步原理

    这篇文章主要介绍了一文详解MySQL主从同步原理,MySQL主从同步是基于Bin Log实现的,而Bin Log记录的是原始SQL语句,更多相关内容介绍感兴趣的小伙伴可以参...

    一灯架构7692022-08-16
  • Mysqlmysql 8.0.11安装教程图文解说

    mysql 8.0.11安装教程图文解说

    本文通过图文并茂的形式给大家介绍了mysql 8.0.11安装教程,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下...

    放牛男孩9882020-09-21
  • Mysql为什么MySQL分页用limit会越来越慢

    为什么MySQL分页用limit会越来越慢

    在mysql中limit可以实现快速分页,但是如果数据到了几百万时我们的limit必须优化才能有效的合理的实现分页了,否则可能卡死你的服务器...

    程序员阿牛5622021-09-01
  • MysqlMySQL数据库备份恢复实现代码

    MySQL数据库备份恢复实现代码

    这篇文章主要介绍了MySQL数据库备份恢复实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考...

    Hedger_Lee10142021-01-21
  • MysqlMysql设置主键自动增长起始值的方案总结

    Mysql设置主键自动增长起始值的方案总结

    在MySQL 中,当主键定义为自增长后,这个主键的值就不再需要用户输入数据了,而由数据库系统根据定义自动赋值,下面这篇文章主要给大家介绍了关于Mysql设置...

    菜鸟是大神4022022-11-09