1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column。
时间: 2023-11-12 16:00:27 浏览: 163
这个错误通常是因为在 SELECT 语句中,有些列没有被包含在 GROUP BY 子句中,而且这些列也没有被聚合函数(如 SUM、COUNT 等)所包含。这在 MySQL 5.7 版本之后是默认的行为,可以通过设置 sql_mode 来改变。
如果你想要解决这个问题,可以将所有未聚合的列都添加到 GROUP BY 子句中,或者使用聚合函数来计算这些列的值。
相关问题
1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column
这个错误是由于在SQL查询中,SELECT列表中的某一列没有包含在GROUP BY子句中,并且该列不是聚合列导致的。这个错误通常发生在使用GROUP BY子句进行分组查询时。
解决这个问题的方法有两种:
1. 将SELECT列表中的所有列都添加到GROUP BY子句中。这样可以确保所有的列都被正确地分组。
2. 如果你只想要对某些列进行分组,而不是所有的列,可以使用聚合函数对其他列进行处理。例如,使用SUM、COUNT、MAX等聚合函数来处理非分组列。
1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column的解决办法
这个错误通常是因为在 SELECT 语句中,GROUP BY 子句中没有包含所有非聚合列。解决方法是将所有非聚合列都包含在 GROUP BY 子句中,或者使用聚合函数对非聚合列进行计算。
例如,如果你有以下 SQL 语句:
```
SELECT name, SUM(sales)
FROM sales_table
GROUP BY name;
```
但是你的表中还有其他列,比如 date,那么你需要将它也包含在 GROUP BY 子句中:
```
SELECT name, date, SUM(sales)
FROM sales_table
GROUP BY name, date;
```
如果你不想将 date 包含在 GROUP BY 子句中,可以使用聚合函数对它进行计算:
```
SELECT name, MAX(date), SUM(sales)
FROM sales_table
GROUP BY name;
```
阅读全文