Working with Json
From A Cheat Sheet for Working with Json in Sql Server
Go to text →
Resources
- https://docs.microsoft.com/en-us/sql/relational-databases/json/json-data-sql-server?view=sql-server-ver15
- https://docs.microsoft.com/en-us/sql/relational-databases/json/solve-common-issues-with-json-in-sql-server?view=sql-server-ver15
There are a few key functions for working with JSON in SQL Server.
OPENJSON
— open a JSON string into a query-able objectFOR
JSON — format data back into a JSON StringISJSON
— check if a string is a valid JSON formatJSON_VALUE
— extract a specific value from a JSON objectJSON_QUERY
— extract embedded objects and lists from a JSON objectJSON_MODIFY
— update values in a JSON object
JSON to VARCHAR
DECLARE @json NVARCHAR(MAX);
SET @json = N'{JSON:HERE}'
Path Expressions
We write JSON “Path Expressions” to get data out of objects with either the JSON_VALUE
or JSON_QUERY
Functions.
The Path Expressions allow for the following patterns.
Querying JSON Objects
Rename Values on Selection
JSON_MODIFY(<json object>, <path to select>, <new value>)
Lax vs Strict mode
JSON queries can also use a lax or strict mode to help control the behavior when data does not exist or when fields are not found. Specifying the mode at the beginning of a query string will enforce the mode.
SELECT * FROM OPENJSON(@json, N'lax $.info');