如何在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










posted on 2022-05-30 16:47  德邦总管  阅读(466)  评论(0编辑  收藏  举报

导航