9

listunagg関数のようなオラクルにそのようなものはありますか?たとえば、次のようなデータがある場合:

ユーザーID 度_fi 度_en 度_sv
3601464 3700 1600 2200
1020 100 0 0
3600520 100,3200,400 1300、800、3000 1400、600、1500
3600882 0 100 200

次のようなデータを表示したいと思います。

ユーザーID 度_fi 度_en 度_sv
3601464 3700 1600 2200
1020 100 0 0
3600520 100 1300 1400
3600882 0 100 200
3600520 3200 800 600
3600520 400 3000 1500

の反対のような関数を見つけようとしましlistaggたが、見つかりませんでした。

4

3 に答える 3

9

@be hereがコメントですでに述べているように、Oracleはそのような関数を提供していません。したがって、簡単な回避策として、同様のクエリを作成できます。

with t1(user_id, degree_fi, degree_en, degree_sv) as
(
  select 3601464, '3700', '1600', '2200' from dual union all
  select 1020   , '100' , '0'   , '0'    from dual union all
  select 3600520, '100,3200,400', '1300, 800, 3000', '1400, 600, 1500'  from dual union all
  select 3600882, '0',    '100',  '200'  from dual
),
Occurence(ocr) as(
  select Level as ocr
    from (select max(greatest(regexp_count(degree_fi, '[^,]+')
                             , regexp_count(degree_en, '[^,]+')
                             , regexp_count(degree_sv, '[^,]+')
                             )
                    ) mx
            from t1    
          ) 
    connect by level <= mx
)
select *
  from (
select User_id
     , regexp_substr(degree_fi, '[^,]+', 1, o.ocr) as degree_fi
     , regexp_substr(degree_en, '[^,]+', 1, o.ocr) as degree_en
     , regexp_substr(degree_sv, '[^,]+', 1, o.ocr) as degree_sv
   from t1 t
  cross join Occurence o
)
where degree_fi is not null
  or degree_en is not null 
  or degree_sv is not null

結果:

User_Id   Degree_Fi  Degree_En  Degree_Sv
------------------------------------------------------------ 
3601464   3700       1600       2200 
1020      100        0          0 
3600520   100        1300       1400 
3600882   0          100        200 
3600520   3200       800        600 
3600520   400        3000       1500 
于 2012-11-02T05:52:42.873 に答える
0

OraOpenSourceUtilsパッケージセットによって提供されるlistunagg機能があります。それもうまくいきます。

于 2018-04-26T10:30:56.690 に答える
-1

リストを削除するには、オラクルの「Ask Tom」でトムが何を言っているかを検討してください。https: //blogs.oracle.com/oraclemagazine/on-cursors-sql-and-analytics コードリスト3または4を参照してください。

トムが説明していない私の好みのオプションは、短い文字列(<34文字)に適しています。OracleDBMS_UTILITY.comma_to_table関数を使用しています。例:

SET SERVEROUTPUT ON
DECLARE
/** test data **/   
  L_LIST1   VARCHAR2(500) := '"A","B","C","Pierre - Andre","D","E","OFVampFVapos;CBryan","F","G","H","I","J"';
  l_list2   VARCHAR2(500);
  l_tablen  BINARY_INTEGER;
  l_tab     DBMS_UTILITY.uncl_array;
BEGIN
  DBMS_OUTPUT.put_line('l_list1 : ' || l_list1);

  DBMS_UTILITY.comma_to_table (
     list   => l_list1,
     tablen => l_tablen,
     tab    => l_tab);

  FOR i IN 1 .. l_tablen LOOP
    DBMS_OUTPUT.put_line(i || ' : ' || l_tab(i));
  END LOOP;

  DBMS_UTILITY.table_to_comma (
     tab    => l_tab,
     tablen => l_tablen,
     list   => l_list2);

  DBMS_OUTPUT.put_line('l_list2 : ' || l_list2);
end;
于 2014-06-17T22:50:10.433 に答える