postgre group by 报错
时间: 2023-11-14 11:27:52 浏览: 110
在PostgreSQL中,当使用GROUP BY语句时,SELECT语句中的字段必须与GROUP BY子句中的字段匹配。这是因为在SQL3(1999)标准之前,数据库引擎无法确定在GROUP BY的情况下如何处理未在GROUP BY子句中列出的字段的值。如果SELECT语句中的字段没有正确地放置在GROUP BY子句中,就会导致报错。
对于你提到的错误,可能是因为SELECT语句中的字段没有正确地放置在GROUP BY子句中导致的。如果你移除了min和max函数,或者去掉其他字段,那么这个错误可能不会出现。
值得注意的是,大多数数据库引擎都不允许SELECT语句中的字段不在GROUP BY子句中的操作,即使在MySQL的5.7版本后也需要打开一个选项才能使用。
如果你在执行类似下面的语句时出现错误:
SELECT cname, wmname, MAX(avg) FROM makerar GROUP BY cname;
可能是因为cname或wmname字段没有在GROUP BY子句中列出所导致的错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [postgreSQL使用sql归一化数据表的某列,以及出现“字段 ‘xxx’ 必须出现在 GROUP BY 子句中或者在聚合函数...](https://blog.csdn.net/df1445/article/details/106783849)[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_1"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [关于postgresql group by 报错 的问题](https://blog.csdn.net/tianbao668/article/details/112171774)[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_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文