我使用的是 Postgres 9.4 版,并且表中有一个 full_name
字段。
在某些情况下,我想在我的表中放置姓名首字母而不是该人的全名。
就像是:
Name | Initials
------------------------
Joe Blow | J. B.
Phil Smith | P. S.
full_name
字段是一个字符串值(显然),我认为最好的方法是将字符串拆分为一个数组 foreach 空间,即:select full_name, string_to_array(full_name,' ') initials
from my_table
这会产生以下结果集:
Eric A. Korver;{Eric,A.,Korver}
Ignacio Bueno;{Ignacio,Bueno}
Igmar Mendoza;{Igmar,Mendoza}
现在,我唯一缺少的是如何遍历每个数组元素并从中取出第一个字符。我最终将使用
substring()
来获取每个元素的初始字符 - 但是我只是坚持如何即时循环它们..任何人都有一个简单的方法来解决这个问题?
最佳答案
将 unnest
与 string_agg
一起使用:
select full_name, string_agg(substr(initials, 1,1)||'.', ' ') initials
from (
select full_name, unnest(string_to_array(full_name,' ')) initials
from my_table
) sub
group by 1;
full_name | initials
------------------------+-------------
Phil Smith | P. S.
Joe Blow | J. B.
Jose Maria Allan Pride | J. M. A. P.
Eric A. Korver | E. A. K.
(4 rows)