SQL将ORDER BY结果作为数组返回

Ear*_*ind 3 php mysql sql postgresql

是否可以将组作为关联数组返回?我想知道是否可以使用纯SQL解决方案.请注意,我发布我可能会使事情变得更加复杂,但这主要是为了让我了解SQL的强大功能.

我的问题:我在数据库中有一个单词列表,应该按字母顺序排序,并根据单词的第一个字母分组到不同的组中.

例如:

ape
broom
coconut
banana
apple
Run Code Online (Sandbox Code Playgroud)

应该归还为

array(
'a' => 'ape', 'apple',
'b' => 'banana', 'broom',
'c' => 'coconut'
)
Run Code Online (Sandbox Code Playgroud)

所以我可以通过第一个字母轻松创建排序列表(即点击"A"只显示以a开头的单词,"B"表示带b,等等.这样可以让我更容易在一个查询中加载所有内容并生成排序列表JavaScript基于,即无需重新加载页面(或使用AJAX).

附注:我正在使用PostgreSQL,但MySQL的解决方案也不错,所以我可以尝试将其移植到PostgreSQL.脚本语言是PHP.

Bil*_*win 6

MySQL的:

SELECT LEFT(word, 1) AS first_letter, 
  GROUP_CONCAT(word) AS word_list
FROM MyTable
GROUP BY LEFT(word, 1);
Run Code Online (Sandbox Code Playgroud)

PostgreSQL 8.4:

SELECT SUBSTRING(word FOR 1) AS first_letter, 
  ARRAY_TO_STRING(ARRAY_AGG(word), ',') AS word_list
FROM MyTable
GROUP BY SUBSTRING(word FOR 1);
Run Code Online (Sandbox Code Playgroud)

有关在PostgreSQL中模拟MySQL的更多信息,请参阅http://mssql-to-postgresql.blogspot.com/2007/12/cool-groupconcat.htmlGROUP_CONCAT().

有关详细信息,请参阅http://www.postgresonline.com/journal/index.php?/archives/126-PostgreSQL-8.4-Faster-array-building-with-array_agg.htmlARRAY_AGG().