MySQL解决报错:Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column. macbook怎么解决这个报错
时间: 2023-12-29 15:26:05 浏览: 160
mysql8.0.20下载安装及遇到的问题(图文详解)
在MySQL中,当使用GROUP BY子句对结果进行分组时,SELECT列表中的列必须要么是分组的列,要么是聚合函数的结果。否则,会出现报错"Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column"。解决这个报错的方法有两种:
1. 使用聚合函数对非分组列进行聚合操作。
2. 修改MySQL的sql_mode参数,将其设置为非严格模式。
下面是两种解决方法的示例:
方法一:使用聚合函数对非分组列进行聚合操作
```sql
SELECT custname, MAX(salary) FROM your_table GROUP BY custname;
```
方法二:修改MySQL的sql_mode参数
```sql
SET sql_mode = 'ONLY_FULL_GROUP_BY,NO_AUTO_CREATE_USER';
```
请注意,修改sql_mode参数可能会影响其他查询的行为,因此在修改之前请确保了解其影响。
阅读全文