which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mod

这篇具有很好参考价值的文章主要介绍了which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mod。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

mysql 执行报错

Expression #2 of SELECT list is not in GROUP BY clause and contains
nonaggregated column ‘bcdsystem.cities.city’ which is not functionally
dependent on columns in GROUP BY clause; this is incompatible with
sql_mode=only_full_group_by"

1.这个错误发生在mysql 5.7 版本及以上版本会出现的问题:

   mysql 5.7版本默认的sql配置是:sql_mode="ONLY_FULL_GROUP_BY",这个配置严格执行了"SQL92标准"

2.在sql执行时,出现该原因:

    简单来说就是:输出的结果是叫target list,就是select后面跟着的字段,还有一个地方group by column,就是

    group by后面跟着的字段。由于开启了ONLY_FULL_GROUP_BY的设置,所以如果一个字段没有在target list 

    和group by字段中同时出现,或者是聚合函数的值的话,那么这条sql查询是被mysql认为非法的,会报错误。

3.解决方法
1)可以采取临时解决方法,但mysql重启后仍然会报这个错误

查看版本号:select version();

可以看到我的版本是5.7版本以上的,
    which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mod,linux,数据库,docker,sql,mysql,数据库

查询模型:SELECT @@GLOBAL.sql_mode; SELECT @@SESSION.sql_mode;

which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mod,linux,数据库,docker,sql,mysql,数据库
可以看到mysql的配置是含有sql_mode="ONLY_FULL_GROUP_BY"的,

接下来执行以下4条sql语句即可解决 (重启mysql会失效):

set sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
 
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';
 
set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
 
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';

2)最终解决办法:修改MySQL的配置文件

我是在linux服务上用docker安装的mysql,进入mysql容器中,进入/etc/mysql目录下修改my.cnf文件

vim /etc/mysql/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

【例外】
但是经过我cat my.conf 发现此配置文件并没有[mysqld]这一项 看到配置文件中引入了/etc/mysql/conf.d/, /etc/mysql/mysql.conf.d/两个目录中的文件

经过查看 在引入的文件mysql.conf.d文件夹下有个mysqld.cnf文件中含有[mysqld]配置 便在该配置文件中加入上述的配置,保存之后重启mysql容器,这样便可永久解决问题。

vim /etc/mysql/mysql.conf.d/mysqld.cnf

添加如下语句:

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

ps:不同的系统,mysql 的配置文件名以及路径不同
1、Mac或Linux文件 /etc/my.cnf
2、windows 在数据库安装目录下的 my.ini文章来源地址https://www.toymoban.com/news/detail-560420.html

到了这里,关于which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mod的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包