SQL OPENJSON funkce – Jak parsovat JSON soubory?

Jedna z novinek, která přišla v nedávných SQL Server verzích je nativní podpora pro JSON formáty. Tato novinka přišla s SQL verzí 2016 (psal jsem o tom v tomto článku). JSON soubor je strukturovaný zápis dat pomocí jednoduché notace (podobně jako např. XML). Podívejme se blíže na novou funkci – OPENJSON.

Příklad na SQL funkci OPENJSON

Z  rezervační aplikace na prodej zájezdů nám přišel JSON soubor, který má následující strukturu:

[ { “Registrace”: { “Cislo_zakaznika”:”123456″, “Datum_registrace”:”2018-07-02″ }, “Zajezd”: { “Cena_zajezdu”:2024.9940, “Pocet_cestujicich”:1 } } ]

Soubor tedy obsahuje 1 řádek a 4 sloupce:

  • Cislo_zakaznika
  • Datum_registrace
  • Cena_zajezdu
  • Pocet_cestujicich

Pomocí funkce si zobrazíme sloupce – Cislo_zakaznika, Datum_registrace a Cena_zajezdu

DECLARE @JSON_TEXT NVARCHAR(MAX)
SET @JSON_TEXT =
N'[
        {
                “Registrace”: {
                “Cislo_Zakaznika”:”123456″,
                “Datum_registrace”:”2018-07-02″
             },”Zajezd”: {
                “Cena_zajezdu”:20000,
                “Pocet_cestujicich”:1
             }
         }
]’

SELECT *
FROM
OPENJSON ( @JSON_TEXT )
WITH (
Cislo_Zakaznika VARCHAR(200)                         ‘$.Registrace.Cislo_Zakaznika’ ,
Datum DATETIME                                                   ‘$.Registrace.Datum_registrace’,
Cena_zajezdu MONEY                                             ‘$.Zajezd.Cena_zajezdu’
)

Výsledek:

Příklad - OPENJSON - Výsledek příkladu

 

 

5/5 - (3 votes)
Rubrika: SQL Funkce Užitečné SQL skripty

O Ing. Jan Zedníček - Data Engineer & Controlling

Jmenuji se Honza Zedníček a působím jako data engineer freelancer. Během cca 10 let jsem zde shromáždil přes 600 IT case studies, průvodců, návodů a tipů určených zejména odborné veřejnosti, studentům a zájemcům o informace z oblastí Data Engineeringu, korporátních financí a reportingu. Zaměřuji se především na Microsoft technologie (on-prem i cloud) a různé synergické efekty v rámci jejich produktového portfolia pro dataře a finanční profesionály. Věnuji se také dalším platformám a významným hráčům z oblasti open source technologií. 🔥 Pokud vám tento článek pomohl, ocením referenci na vašem webu nebo zmínku v komunitě. A mám pro vás ještě tip: řešíte-li nějaký zapeklitý Excel problém, přihlašte se do naší Excel Facebook skupiny (2.4k+ členů), kde si pomáháme Excel CZ/SK diskuse ».

Leave a Reply

Your email address will not be published. Required fields are marked *