如何在 sqlite 中的两个字段上执行 group_concat?
How to do group_concat on two fields in sqlite?
我的cities
table:
year | id | city
2005 10 LA
2005 11 SF
2007 12 NY
2008 13 NO
查询:
SELECT year, GROUP_CONCAT(id)
FROM cities
GROUP BY year
我得到输出:
2005|10,11
2007|12
2008|13
但我想得到的是(例如):
2005|10,LA,11,SF
2007|12,NY
2008|13,NO
换句话说,我想要结果中的 ID 和名称,按年份分组,而不仅仅是 ID。怎么做到的?
在 SQLite 中 GROUP_CONCAT()
接受 2 个参数:要聚合的表达式和分隔符(默认分隔符是 ,
)。
在您的情况下,表达式部分需要多列,因此您必须通过连接来构建它:
SELECT year,
GROUP_CONCAT(id || ',' || city) AS id_city
FROM cities
GROUP BY year;
参见demo。
我的cities
table:
year | id | city
2005 10 LA
2005 11 SF
2007 12 NY
2008 13 NO
查询:
SELECT year, GROUP_CONCAT(id)
FROM cities
GROUP BY year
我得到输出:
2005|10,11
2007|12
2008|13
但我想得到的是(例如):
2005|10,LA,11,SF
2007|12,NY
2008|13,NO
换句话说,我想要结果中的 ID 和名称,按年份分组,而不仅仅是 ID。怎么做到的?
在 SQLite 中 GROUP_CONCAT()
接受 2 个参数:要聚合的表达式和分隔符(默认分隔符是 ,
)。
在您的情况下,表达式部分需要多列,因此您必须通过连接来构建它:
SELECT year,
GROUP_CONCAT(id || ',' || city) AS id_city
FROM cities
GROUP BY year;
参见demo。