乱码乱a∨中文字幕,在线免费激情视频,亚洲欧美久久夜夜潮,国产在线网址

  1. <sub id="hjl7n"></sub>

    1. <sub id="hjl7n"></sub>

      <legend id="hjl7n"></legend>

      當(dāng)前位置:首頁(yè) >  站長(zhǎng) >  數(shù)據(jù)庫(kù) >  正文

      PostgreSQL 對(duì)數(shù)組的遍歷操作

       2021-05-21 16:53  來(lái)源: 腳本之家   我來(lái)投稿 撤稿糾錯(cuò)

        阿里云優(yōu)惠券 先領(lǐng)券再下單

      這篇文章主要介紹了PostgreSQL 對(duì)數(shù)組的遍歷操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧。

      PostgreSQL 提供了數(shù)組類型。

      我來(lái)演示下如何具體使用

      創(chuàng)建一個(gè)有數(shù)組類型字段的表。

      1create table test_array(id serial primary key, str1 int[][][]);

      插入兩條測(cè)試數(shù)據(jù)。

      insert into test_array values (1,array[[[1,2],[3,4],[5,6]],[[20,30],[40,50],[70,100]]]);
      insert into test_array values (2,array[[[100,200],[300,400],[500,600]],[[2000,3000],[4000,5000],[7000,10000]]]);

       

      為了能直觀的看到結(jié)果集,我們得把數(shù)組的值換成普通的類型拿出來(lái), 有以下幾種方法。

      不帶分片的遍歷,

      create or replace function sp_array2table_simple(
      anyarray
      )
      returns table (element int) as
      $ytt$
      declare array1 alias for $1;
       x int;
      begin
       drop table if exists tmp_1;
       create temporary table tmp_1 (id int);
       
       <<label1>> foreach x in array array1
       loop
       insert into tmp_1 values (x);
       end loop label1;
       
       return query select * from tmp_1;
      end;
      $ytt$ language plpgsql;
       
      t_girl=#select sp_array2table_simple(str1) as array_list from test_array where id = 2;
       
       array_list
      ------------
        100
        200
        300
        400
        500
        600
        2000
        3000
        4000
        5000
        7000
        10000
      (12 行記錄)
       
      時(shí)間:7.780 ms

       

      帶分片的遍歷:

      create or replace function sp_array2table(
      anyarray
      )
      returns table (element int) as
      $ytt$
      declare array1 alias for $1;
       x int[];
       nlen int := 0;
       i int := 1;
      begin
       drop table if exists tmp_1;
       create temporary table tmp_1 (id int);
       
       <<label1>> foreach x slice 1 in array array1
       loop
        nlen := array_length(x,1);
        i := 1;
        <<label2>> while i <= nlen loop
        insert into tmp_1 values (x[i]);
        i := i + 1;
        end loop label2;
       end loop label1;
       
       return query select * from tmp_1;
      end;
      $ytt$ language plpgsql;
       
      t_girl=#select sp_array2table(str1) as array_list from test_array where id = 2;
       
       array_list
      ------------
        100
        200
        300
        400
        500
        600
        2000
        3000
        4000
        5000
        7000
        10000
      (12 行記錄)
       
      時(shí)間:20.139 ms

       

      還有就是系統(tǒng)系統(tǒng)了幾個(gè)函數(shù),直接進(jìn)行遍歷,

      比如unnest

      t_girl=#select unnest(str1) as array_list from test_array where id = 2;
       
       array_list
      ------------
        100
        200
        300
        400
        500
        600
        2000
        3000
        4000
        5000
        7000
        10000
      (12 行記錄)
       
      時(shí)間:1.002 ms

       

      比如array_to_string 等。

      t_girl=#select regexp_split_to_table(array_to_string(str1,','),',+') as array_list from test_array where id = 2;
       
       array_list
      ------------
       100
       200
       300
       400
       500
       600
       2000
       3000
       4000
       5000
       7000
       10000
      (12 行記錄)
       
      時(shí)間:0.850 ms

       

      補(bǔ)充:PostgreSQL遍歷Json

      SQL:

      SELECT
       orderno,
       fromno,
       fromamount,
       fromlotno ->> 'index' fromlotno,
       othercondition ->> 'supplicode' supplicode,
       othercondition ->> 'downcode' downcode,
       othercondition ->> 'spec' spec,
       othercondition ->> 'carport' carport
      FROM
       (
       SELECT
       orderno,
       fromno,
       fromamount,
       json_array_elements (fromlotno) fromlotno,
       json_array_elements (othercondition) othercondition
       FROM
       t_feather_source
       ) A

       

      輸出結(jié)果:

      文章來(lái)源:腳本之家

      來(lái)源地址:https://www.jb51.net/article/204921.htm

      申請(qǐng)創(chuàng)業(yè)報(bào)道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!

      相關(guān)文章

      熱門排行

      信息推薦