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

高版本Mysql使用group by分组报错的解决方案

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

高版本Mysql使用group by分组报错的解决方案

mysql5.7版本以上对group by 分组有了新需求,要求group by 后的字段要与select后查询的字段一致,否则就会报错,报错信息如下:

#1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column ‘id’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

通过报错分析是由于group by 后的分组字段与查询字段不一致导致。

解决方案:

方法一:补全group by 后字段(不推荐这种方法,有时要查询的字段很多而且字段的内容不能保证不重复,如果全部补齐会造成查询数据丢失)。

方法二:修改配置

1)使用navicat管理工具连接mysql数据库

打开navicat管理工具,按F6打开命令界面,依次输入以下语句

select @@global.sql_mode;
set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';`
set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

截图如下:

高版本Mysql使用group by分组报错的解决方案

再重新执行就会发现不再报错。

2)使用cmd命令行更改

按win+r打开运行界面,输入cmd打开命令行界面

高版本Mysql使用group by分组报错的解决方案

打开后切换目录到mysql安装包的bin目录下,具体操作如下图(根据自己路径切换)

高版本Mysql使用group by分组报错的解决方案

连接数据库,输入mysql -u root -p,按回车再输入数据库密码

连接成功后再依次输入以下语句

select @@global.sql_mode;
set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

截图如下:

高版本Mysql使用group by分组报错的解决方案

至此配置结束

总结

到此这篇关于高版本Mysql使用group by分组报错的解决方案的文章就介绍到这了,更多相关Mysql使用group by分组报错内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

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

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

高版本Mysql使用group by分组报错的解决方案

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

下载Word文档

猜你喜欢

高版本Mysql使用group by分组报错的解决方案

GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组,下面这篇文章主要给大家介绍了关于高版本Mysql使用group by分组报错的解决方案,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2023-03-06

高版本Mysql使用group by分组报错的解决方案

mysql5.7版本以上对group by 分组有了新需求,要求group by 后的字段要与select后查询的字段一致,否则就会报错,报错信息如下:#1055 - Expression #1 of SELECT list is not
2023-03-06

高版本Mysql使用group by分组报错如何解决

这篇文章主要讲解了“高版本Mysql使用group by分组报错如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“高版本Mysql使用group by分组报错如何解决”吧!Mysql5.
2023-03-09

Mysql高版本不兼容group by解决方案

mysql命令gruop by报错this is incompatible with sql_mode=only_full_group_by出现这个错误已导致在开发中mybatis的sql也运行不了原因:看一下group by的语法:select 选取分组中的
Mysql高版本不兼容group by解决方案
2020-12-24

关于使用MySQL修改用户名密码报错的解决方案

先声明:使用的 MySQL 版本是 8.32 一、关于报错 Operation ALTER USER failed for ‘用户名’@‘localhost’ 是执行了语句: alter user '用户名'@'localhost'
2023-08-30

编程热搜

目录