Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

ऑरैकल 18 में json_table के माध्यम से पार्स जोंस

आप कार्यों को परिभाषित कर सकते हैं:

CREATE FUNCTION get_keys(
  value IN CLOB
) RETURN SYS.ODCIVARCHAR2LIST PIPELINED
IS
  js   JSON_OBJECT_T := JSON_OBJECT_T( value );
  keys JSON_KEY_LIST;
BEGIN
  keys := js.get_keys();
  FOR i in 1 .. keys.COUNT LOOP
    PIPE ROW ( keys(i) );
  END LOOP;
END;
/

CREATE FUNCTION get_value(
  value IN CLOB,
  path  IN VARCHAR2
) RETURN VARCHAR2
IS
  js JSON_OBJECT_T := JSON_OBJECT_T( value );
BEGIN
  RETURN js.get_string( path );
END;
/

फिर क्वेरी का उपयोग करें:

WITH j (sJson) as (
   select '{
      "ID":"1444284517",
      "ID_ORD":"4255;2187606199",
      "Vals":{
               "CODE":"ONB2B3BB8",
               "DORD":"25.04.2021"
             }
   }'
   from dual
)
SELECT jt.id,
       jt.id_ord,
       k.COLUMN_VALUE AS Key,
       get_value( jt.vals, k.COLUMN_VALUE ) AS value
FROM   j
       CROSS APPLY JSON_TABLE(
         j.sjson,
         '$'
         COLUMNS (
           id     VARCHAR2(20) PATH '$.ID',
           id_ord VARCHAR2(30) PATH '$.ID_ORD',
           vals   VARCHAR2(4000) FORMAT JSON PATH '$.Vals'
         )
       ) jt
       CROSS APPLY get_keys( jt.vals ) k

कौन सा आउटपुट:

ID ID_ORD कुंजी VALUE 14442845174255;2187606199CODEONB2B3BB814442845174255;2187606199DORD25.04.2021

(नोट:SQL स्तंभों की एक गतिशील संख्या का समर्थन नहीं करता है, इसलिए आपको निश्चित संख्या में कॉलम प्रदान करने की आवश्यकता है जैसे कि key और value और आउटपुट कॉलम के बजाय पंक्तियों के रूप में है।)

db<>फिडल यहाँ



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Oracle SQL डेवलपर में XML फ़ाइल कैसे आयात करें?

  2. Oracle 12c संस्थापन अस्थायी स्थान तक पहुँचने में विफल रहा

  3. Oracle:SQL क्वेरी जो केवल संख्यात्मक मानों वाली पंक्तियाँ लौटाती है

  4. Oracle तत्काल क्लाइंट DYLD_LIBRARY_PATH त्रुटि

  5. Oracle MD5 हैश फ़ंक्शन को कैसे कॉल करें?