Bagikan melalui


ISJSON (Transact-SQL)

Berlaku untuk: SQL Server 2016 (13.x) dan versi yang lebih baru Azure SQL DatabaseAzure SQL Managed InstanceTitik akhir analitik SQLAzure Synapse Analytics di Microsoft Fabric Warehouse dalam database Microsoft FabricSQL di Microsoft Fabric

Sintaks ISJSON menguji apakah string berisi JSON yang valid.

Konvensi sintaks transact-SQL

Syntax

ISJSON ( expression [, json_type_constraint] )  

Arguments

expression

String yang akan diuji.

json_type_constraint

Menentukan jenis JSON untuk memeriksa input. Nilai yang valid adalah VALUE, ARRAY, OBJECT, atau SCALAR. Diperkenalkan di SQL Server 2022 (16.x).

Note

Argumen json_type_constraint tidak didukung di kumpulan Khusus Azure Synapse Analytics

Mengembalikan nilai

Mengembalikan 1 jika string berisi JSON yang valid; jika tidak, mengembalikan 0. Mengembalikan NULL jika ekspresi null.

Jika pernyataan menghilangkan json_type_constraint, fungsi menguji apakah input adalah objek atau array JSON yang valid dan mengembalikan 1 sebaliknya, ia mengembalikan 0.

Jika json_type_constraint ditentukan, fungsi akan memeriksa jenis JSON sebagai berikut:

Value Description
VALUE Pengujian untuk nilai JSON yang valid. Ini bisa berupa objek JSON, array, angka, string atau salah satu dari tiga nilai harfiah (false, true, null)
ARRAY Pengujian untuk array JSON yang valid
OBJECT Pengujian untuk objek JSON yang valid
SCALAR Pengujian untuk skalar JSON yang valid – angka atau string

Nilai json_type_constraint SCALAR dapat digunakan untuk menguji dokumen JSON sesuai IETF RFC 8259 yang hanya berisi nilai skalar JSON di tingkat atas. Dokumen JSON yang tidak berisi nilai skalar JSON di tingkat atas sesuai dengan IETF RFC 4627.

Tidak mengembalikan kesalahan.

Remarks

ISJSON tidak memeriksa keunikan kunci pada tingkat yang sama.

Examples

Contoh 1

Contoh berikut menjalankan blok pernyataan secara kondisional jika nilai @param parameter berisi JSON yang valid.

DECLARE @param <data type>
SET @param = <value>

IF (ISJSON(@param) > 0)  
BEGIN  
     -- Do something with the valid JSON value of @param.  
END

Contoh 2

Contoh berikut mengembalikan baris di mana kolom json_col berisi JSON yang valid.

SELECT id, json_col
FROM tab1
WHERE ISJSON(json_col) = 1 

Contoh 3

Contoh berikut mengembalikan baris di mana kolom json_col berisi nilai JSON SCALAR yang valid di tingkat atas.

SELECT id, json_col
FROM tab1
WHERE ISJSON(json_col, SCALAR) = 1 

Contoh 4

Contoh berikut mengembalikan 1 karena input adalah nilai JSON yang valid - true.

SELECT ISJSON('true', VALUE)

Contoh 5

Contoh berikut mengembalikan 0 karena input adalah nilai JSON yang tidak valid.

SELECT ISJSON('test string', VALUE)

Contoh 6

Contoh berikut mengembalikan 1 karena input adalah skalar JSON yang valid sesuai dengan RFC 8259.

SELECT ISJSON('"test string"', SCALAR)