如何在Postgres中生成包含数字1到n的数组
我希望有这样的东西存在:
1 SELECT nrange(10) 2 {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
类似于Python和Racket等语言中的range
函数。当然,如果在PostgreSQL中不存在这样的函数,我会非常满意地知道解决这个问题的惯用方法。谢谢!
这与问题How can I generate a series of repeating numbers in PostgreSQL?略有不同,因为我不想生成一系列重复的数字,而是生成一个连续数字的数组。
幸运的是,您使用的是PostgreSQL,因此可以使用generate_series()函数。
1 select generate_series as num from generate_series(1,10)
如果您需要一个数组,可以将这些值聚合到一个数组中:
1 select array_agg(gs.val order by gs.val) 2 from generate_series(1, 10) gs(val);
本文参考:https://cloud.tencent.com/developer/ask/sof/1263782