14-ma’ruza. Xml va json ma’lumotlar bazasi


JSON_VALUE funksiyasi ma'lumotlar ustunida saqlangan JSON



Download 284,57 Kb.
bet12/12
Sana23.07.2022
Hajmi284,57 Kb.
#843109
1   ...   4   5   6   7   8   9   10   11   12
Bog'liq
14-ma\'ruza

JSON_VALUE funksiyasi ma'lumotlar ustunida saqlangan JSON matnidan qiymatni oladi. Ushbu funktsiya JSON matnida olingan qiymatga murojaat qilish uchun JavaScript-ga o'xshash yo'ldan foydalanadi. Olingan qiymat SQL so'rovining istalgan qismida ishlatilishi mumkin.
JSON_QUERY funktsiyasi JSON_VALUE funksiyasiga o'xshash. JSON_VALUE dan farqli o'laroq, ushbu funksiya JSON matniga mos keladigan massivlar yoki obyektlar kabi murakkab subyektlarni oladi.
JSON_MODIFY funksiyasi sizga yangilanadigan JSON matnidagi yo'lni, shuningdek eski qiymatni almashtirish uchun yangi qiymatni belgilashga imkon beradi. Shunday qilib, JSON matnini barcha tuzilmani tahlil qilmasdan osongina yangilashingiz mumkin.
JSON ma'lumotlari oddiy matnda saqlanganligi sababli, matn ustunlarida saqlangan qiymatlar to'g'ri formatlanganligiga kafolat yo'q. Siz Azure SQL ma'lumotlar bazasini tekshirish cheklovlari va ISJSON funktsiyasidan foydalangan holda JSON ustunida saqlangan matnning to'g'ri formatlanganligini tekshirishingiz mumkin.

ALTER TABLE Products


ADD CONSTRAINT [Data should be formatted as JSON]
CHECK (ISJSON(Data) > 0)

Agar kiritilgan matn to'g'ri JSON formatida bo'lsa, ISJSON funktsiyasi 1 qaytadi, har safar JSON ustuni qo'shilganda yoki yangilanganda, ushbu cheklash yangi matn qiymatining JSON formati to'g'ri yoki yo'qligini tekshiradi.




JSON ma'lumotlarini jadval formatiga o'tkazish
Azure SQL ma'lumotlar bazasi va Azure SQL boshqariladigan holati JSON to'plamlarini jadval formatiga o'zgartirish va JSON ma'lumotlarini yuklash yoki so'rashga imkon beradi.
OPENJSON - bu JSON matnini tahlil qiladigan, JSON obyektlarining ketma-ketligini topadigan, qator elementlari ustida iteratsiya qilinadigan va chiqishdagi har bir qator elementlari uchun bitta qatorni qaytaradigan jadvalga asoslangan funksiya.


Yuqoridagi misolda JSON massivini qayerdan ($Orders yo'lida) qidirish kerakligini, natijada qaysi ustunlar qaytarilishi kerakligini va yacheykalar sifatida qaytariladigan JSON qiymatlarini qayerdan qidirishni belgilashingiz mumkin.


@Orders o'zgaruvchisi JSON qatorini qatorlar qatoriga o'zgartirishi, natijalar to'plamini tahlil qilishi yoki standart jadvalga qatorlarni qo'shishi mumkin.

CREATE PROCEDURE InsertOrders(@orders nvarchar(max))


AS BEGIN

insert into Orders(Number, Date, Customer, Quantity)


select Number, Date, Customer, Quantity
FROM OPENJSON (@orders)
WITH (
Number varchar(200),
Date datetime,
Customer varchar(200),
Quantity int
)
END


JSON qatori sifatida formatlangan va saqlanadigan protsedura uchun parametr sifatida ko'rsatilgan buyruqlar to'plamini tahlil qilish va Orders jadvaliga kiritish mumkin.
Download 284,57 Kb.

Do'stlaringiz bilan baham:
1   ...   4   5   6   7   8   9   10   11   12




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish