Mysql中使用group by遇到的问题

今天预发环境上报了一个错
看了下日志,是下面的sql报了错

SELECT
	p.* 
FROM
	out_warehouse_plan p 
WHERE
	p.is_delete = 0 
	AND p.plan_code LIKE 'FH%'
GROUP BY
	p.plan_code 
ORDER BY
	p.id DESC;

看了老半天,没看出sql有什么问题

把sql放在Navicat中执行了下,报错如下:

Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'tiger.p.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

在网上查了下:
问题出现的原因:
  MySQL 5.7.5及以上功能依赖检测功能。如果启用了ONLY_FULL_GROUP_BY SQL模式(默认情况下),MySQL将拒绝选择列表,HAVING条件或ORDER BY列表的查询引用在GROUP BY子句中既未命名的非集合列,也不在功能上依赖于它们。(5.7.5之前,MySQL没有检测到功能依赖关系,默认情况下不启用ONLY_FULL_GROUP_BY。有关5.7.5之前的行为的说明,请参见“MySQL 5.6参考手册”。)

解决方法一:

打开navcat,

用sql查询:

select @@global.sql_mode

查询出来的值为:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

去掉ONLY_FULL_GROUP_BY,重新设置值。

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’;

解决方法二:

成功的步骤:

iterm打开

sudo vim /etc/mysql/conf.d/mysql.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

到文件的底部

保存并退出输入模式

sudo service mysql restart

重启MySQL。
完成!
如下图:
在这里插入图片描述

在这里插入图片描述

据说第一种是临时设置,重启mysql之后设置就失效,第二种是永久设置。

原文:https://blog.csdn.net/qq_34707744/article/details/78031413

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用的错误信息提示了一个与"sql_mode=only_full_group_by"相关的错误。这个错误是由于MySQL的版本升级到5.7后引入了新的严格模式,其一个严格模式就是"only_full_group_by"。这个模式要求在执行GROUP BY聚合操作时,SELECT语句的列必须要么出现在GROUP BY子句,要么作为聚合函数的参数。如果SELECT语句的列既不在GROUP BY子句,也不在聚合函数,那么会产生该错误。 引用提供了关于解决MySQL 5.7GROUP BY查询问题的解决方法。根据该引用的描述,可以通过两种方式解决这个问题。第一种方式是将GROUP BY子句的列都添加到SELECT语句,以确保所有列都符合严格模式的要求。第二种方式是使用聚合函数来替代那些没有出现在GROUP BY子句的列。 引用进一步解释了"only_full_group_by"模式的意义,即对于GROUP BY聚合操作,所有在SELECT语句的列都必须要么出现在GROUP BY子句,要么作为聚合函数的参数。 因此,要解决mysql5.7执行GROUP BY查询的问题,你可以通过将GROUP BY子句的列添加到SELECT语句或者使用聚合函数来替代那些没有出现在GROUP BY子句的列。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [MySQL5.7版本group by错误](https://blog.csdn.net/GuangPeng_Ding/article/details/124867682)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [Mysql升级到5.7后遇到group by查询问题解决](https://download.csdn.net/download/weixin_38596093/12826519)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值