簡體   English   中英

解析Oracle中的多個Json數組元素

[英]Parse Multiple Json Array Elements in Oracle

我必須在 oracle 中解析以下 json,其中包含如下所示的數組元素

{"orgPhoneNum":[["9952044727"],["5464646464"]]}

我試過下面的聲明

SELECT JSON_QUERY('{"orgPhoneNum":[["9952044727"],["5464646464"]]}', '$.orgPhoneNum') 
  FROM DUAL;

返回結果像

在此處輸入圖像描述

但我想得到這樣的結果

9952044727,5464646464

我需要在查詢中進行哪些更改?

您可以使用JSON_TABLE獲取數組值,然后使用LISTAGG進行聚合:

SELECT LISTAGG( orgPhoneNum, ',' ) WITHIN GROUP ( ORDER BY row_number )
         AS orgPhoneNums
FROM   JSON_TABLE(
         '{"orgPhoneNum":[["9952044727"],["5464646464"]]}',
         '$.orgPhoneNum[*][*]'
         COLUMNS (
           row_number FOR ORDINALITY,
           orgPhoneNum VARCHAR2(10) PATH '$'
         )
       )

哪些輸出:

  | 有機體 |  |:-------------------- |  |  9952044727,5464646464 |

db<> 在這里擺弄

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM