如何在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   德邦总管  阅读(509)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
历史上的今天:
2019-05-30 cas的单点登录实现
2019-05-30 控制反转(IOC)和依赖注入(DI)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示