大佬教程收集整理的这篇文章主要介绍了arrays – 规范化1维数组的数组下标,使它们从1开始,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
SELECT ('[5:7]={1,2,3}'::int[]);
返回:
[5:7]={1,3}
例如,你得到第一个元素的含义
SELECT ('[5:7]={1,3}'::int[])[5];
我想规范化任何给定的1维数组以从数组下标1开始.
我能想到的最好的:
SELECT ('[5:7]={1,3}'::int[])[array_lower('[5:7]={1,3}'::int[],1):array_upper('[5:7]={1,1)]
或者,同样,更容易阅读:
WITH x(a) AS ( SELECT '[5:7]={1,3}'::int[] ) SELECT a[array_lower(a,1):array_upper(a,1)] FROM x
你知道更简单/更快或更优雅的方式吗?
基准
为了测试性能,我提出了这个快速基准测试.
表有100k行,随机长度在1和11之间的简单整数数组:
CREATE temp table t (a int[]); INSERT INTO t -- now with actually varying subscripts SELECT ('[' || g%10 || ':' || 2*(g%10) || ']={1' || repeat(','||g::text,g%10) || '}')::int[] FROM generate_series(1,100000) g; EXPLAIN ANALYZE SELECT subString(a::text,'{.*$')::int[] -- @R_783_10586@l runtime: 949.304 ms -- a[-2147483648:2147483647] -- @R_783_10586@l runtime: 283.877 ms -- a[array_lower(a,1)] -- @R_783_10586@l runtime: 311.545 ms FROM t
所以,是的,@ Daniel的想法稍快一些.
@Kevin的文字转换也有效,但不会赚很多分.
还有其他想法吗?
以上是大佬教程为你收集整理的arrays – 规范化1维数组的数组下标,使它们从1开始全部内容,希望文章能够帮你解决arrays – 规范化1维数组的数组下标,使它们从1开始所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。