0

我正在使用postgresql 9.0 我想知道是否可以将三个属性连接在一起。

这就是我连接两个属性(书和逗号)的方式:

SELECT string_agg(book, ',') FROM authors where id = 1;


| book1,book2,book3|
--------------------

我该怎么做如下:

SELECT string_agg(name, ':', book, ',') FROM authors where id = 1;

| Ahmad: book1,book2,book3|
  ----------------

有人可以帮忙吗?谢谢。

4

2 回答 2

4

只需像这样连接字段:

SELECT name || ':' || string_agg(book, ',') FROM authors where id = 1;

编辑:

如果您的 SQL 返回多个名称,您需要按名称分组(如果您有多个同名作者,它会变得有点复杂。我不会在这个答案中介绍这种情况):

SELECT name || ':' || string_agg(book, ',') 
  FROM authors where id = 1 
 GROUP BY name;

如果您想要按字母顺序排列的书籍,您可以ORDER BY为书籍添加:

SELECT name || ':' || string_agg(book, ',') WITHIN GROUP ORDER BY book 
  FROM authors where id = 1 
 GROUP BY name;
于 2014-10-07T10:29:28.593 回答
1
SELECT name || ': ' || string_agg(book, ',') FROM authors where id = 1 group by name ;
于 2014-10-07T11:57:25.057 回答