如何在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
标签:
postgresql数据库
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
2019-05-30 cas的单点登录实现
2019-05-30 控制反转(IOC)和依赖注入(DI)