arrays – 规范化1维数组的数组下标,使它们从1开始

arrays – 规范化1维数组的数组下标,使它们从1开始,第1张

概述PostgreSQL可以在任何地方开始使用数组下标. 考虑这个创建一个包含3个元素的数组的示例,其中包含5到7的下标: SELECT ('[5:7]={1,2,3}'::int[]); 返回: [5:7]={1,2,3} 例如,你得到第一个元素的含义 SELECT ('[5:7]={1,2,3}'::int[])[5]; 我想规范化任何给定的1维数组以从数组下标1开始. 我能想到的最好的: SEL Postgresql可以在任何地方开始使用数组下标.
考虑这个创建一个包含3个元素的数组的示例,其中包含5到7的下标:
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 subscriptsSELECT ('[' || g%10 || ':' || 2*(g%10) || ']={1'            || repeat(','||g::text,g%10) || '}')::int[]FROM   generate_serIEs(1,100000) g;EXPLAIN ANALYZESELECT        substring(a::text,'{.*$')::int[]       -- Total runtime: 949.304 ms--     a[-2147483648:2147483647]               -- Total runtime: 283.877 ms--     a[array_lower(a,1)]  -- Total runtime: 311.545 msFROM   t

所以,是的,@ DanIEl的想法稍快一些.
@Kevin的文字转换也有效,但不会赚很多分.

还有其他想法吗?

有一个更简单的方法是丑陋的,但我认为技术上正确:从数组中提取最大可能的切片,而不是具有计算边界的精确切片.
它避免了两个函数调用.

例:

select ('[5:7]={1,3}'::int[])[-2147483648:2147483647];

结果是:

  int4   --------- {1,3}
总结

以上是内存溢出为你收集整理的arrays – 规范化1维数组的数组下标,使它们从1开始全部内容,希望文章能够帮你解决arrays – 规范化1维数组的数组下标,使它们从1开始所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1181351.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存