将MySQL select转换为PostgreSQL
我有此查询在MySQL中正常工作。这里有更多背景信息。
SELECT c.*, SUM(ABS(v.vote)) AS scoreFROM categories c,items i, votes v
WHERE c.id = i.category_id
AND i.id = v.voteable_id
AND v.created_at > '#{1.week.ago}'
GROUP BY c.id
ORDER BY score DESC LIMIT 8;
我尝试在PostgreSQL中运行它,但此错误消息失败。
PGError:错误:列“ c.name”必须出现在GROUP BY子句中或在聚合函数中使用
我不确定这是什么意思,所以我尝试在group by子句中将“ c.id”更改为“ c.name”(在MySQL中两者都是相同的,假定项的名称是唯一的)。
但是,这又产生了另一个类似的错误
PGError:错误:列“ c.id”必须出现在GROUP BY子句中或在聚合函数中使用
该问题如何解决?
回答:
您必须在要分组的SELECT中列出列名:
SELECT c.id, c.name, SUM(ABS(v.vote)) AS scoreFROM categories c,items i, votes v
WHERE c.id = i.category_id
AND i.id = v.voteable_id
AND v.created_at > '#{1.week.ago}'
GROUP BY c.id, c.name
ORDER BY score DESC LIMIT 8;
“不允许在SELECT子句中包括GROUP BY子句中未引用的列名。”
以上是 将MySQL select转换为PostgreSQL 的全部内容, 来源链接: utcz.com/qa/409538.html