技术文摘
MySQL 5.7 报错 1055 的解决办法
MySQL 5.7 报错 1055 的解决办法
在使用 MySQL 5.7 数据库的过程中,报错 1055 是一个较为常见的问题,它会给数据库的正常运行和开发工作带来阻碍。深入了解并掌握有效的解决办法,对于数据库管理员和开发者来说至关重要。
MySQL 1055 错误通常源于“Expression #n of SELECT list is not in GROUP BY clause and contains nonaggregated column 'xxx' which is not functionally dependent on columns in GROUP BY clause”。简单来讲,就是在使用 GROUP BY 语句时,SELECT 列表中的列没有正确处理。按照 SQL 标准,如果使用了 GROUP BY,SELECT 后面的列要么包含在 GROUP BY 子句中,要么使用聚合函数(如 SUM、AVG、COUNT 等)进行处理。
解决这一问题,有几种实用的方法。可以调整查询语句,确保 SELECT 列表中的所有非聚合列都包含在 GROUP BY 子句中。例如,原查询语句为“SELECT column1, column2, AVG(column3) FROM table1 GROUP BY column1;”,若 column2 未参与聚合操作,就需要将其添加到 GROUP BY 子句中,改为“SELECT column1, column2, AVG(column3) FROM table1 GROUP BY column1, column2;”。
也可以使用聚合函数来处理 SELECT 列表中的非 GROUP BY 列。比如“SELECT column1, COUNT(column2), AVG(column3) FROM table1 GROUP BY column1;”,这里使用 COUNT 函数对 column2 进行处理,使其符合 SQL 标准。
另外,通过修改 MySQL 的配置参数 sql_mode 也能解决该问题。在 MySQL 配置文件(通常是 my.cnf 或 my.ini)中,找到 sql_mode 配置项,将 ONLY_FULL_GROUP_BY 模式移除。例如,原本的 sql_mode 配置为“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”,修改后为“sql_mode=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 模式可能会导致查询结果不符合 SQL 标准。
在遇到 MySQL 5.7 报错 1055 时,根据实际情况选择合适的解决方法,能够快速恢复数据库的正常运行,确保开发和运维工作的顺利进行。
- 深入剖析 Java 虚拟机:借助 VisualVM 对高并发项目展开性能解析
- 无需编程!掌握此工具,图表联动瞬间达成
- 深入探究 Class 类:掌握反射必杀技,一通百通
- Python 达成图片中所有人脸的识别与显示
- 微服务中保证事务一致性的深度剖析
- 8 大开发员必用的网页应用程序,好用到哭!
- 实测两款 GitHub 开源插件:踩坑经验分享
- 年末临近,16 个值得关注的 Java 开源项目!
- 25 个极具价值的 Python 代码段
- 浅析大型 IDE 技术架构:以 VSCode 为例
- 2020 年八大科技热点:华为与台积电、5G 激烈竞争、RISC-V 与 Arm 抗衡、存储热潮
- Java 14 将至,为何众多人仍坚守 Java 8?
- Docker 安全开源工具推荐
- Python 2 与 3 共存 11 年,新年将与之告别
- Spring 源码熟悉度:所涉设计模式知多少?