我的 Event_type 列中有看起来像 Music92838、Entertainment298928、SPORTS2837 等的数据,我正在尝试创建一个 View ,按 event_type 对表演次数进行分组
我试过
CREATE VIEW Performances_Type_Cnt
AS SELECT regexp_replace(E.event_type, '[^a-zA-Z]', '', 'g') AS Event_Type,
COUNT(*)
FROM Event_Type E, Performance P
WHERE E.event_id = P.event_id
GROUP BY Event_Type;
使用正则表达式只选择字符,然后在 Group By Event_type 中按 Music、Sports 等进行分组。但是在我得到的结果中有些东西不起作用
event_type | count
---------------+-------
MUSIC | 1
SPORTS | 5
MUSIC | 8
MUSIC | 3
其中 Music 在 event_type 中多次出现,这不是正确的结果。
感谢所有帮助!
最佳答案
“问题”是 Postgres 允许在 GROUP BY
中使用列别名。因此,对于 EVENT_TYPE
是来自表还是来自别名感到困惑。一种简单的解决方案是使用位置表示法:
CREATE VIEW Performances_Type_Cnt AS
SELECT regexp_replace(E.event_type, '[^a-zA-Z]', '', 'g') AS Event_Type,
COUNT(*) as cnt
FROM Event_Type E JOIN
Performance P
ON E.event_id = P.event_id
GROUP BY 1;
我做了一些其他的改变:
- 用显式
JOIN
替换了隐式连接。这是在 SQL 中编写联接的标准方法。 - 为
COUNT(*)
添加了列别名。
关于sql - 通过不正确分组来创建带有组的 View ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36376883/