sql >> Databasteknik >  >> RDS >> Sqlserver

SQL Server JSON_Modify, hur uppdaterar jag alla?

Här är två alternativ. Ansvarsfriskrivning:Jag är inte ett proffs på JSON genom sql server 2016, men jag har hackat en del saker tillsammans.

Alternativ 1:Du skapar helt klart en resultatuppsättning från JSON-strängen. Varför inte skapa resultatuppsättningen och sedan uppdatera den?

DECLARE @jsontable TABLE (A varchar(50), b varchar(50), c varchar(50))
DECLARE @JSON NVARCHAR(MAX)

SET @JSON = 
N'{
"A":1,
"TMP": [    
    {"A":"VALUE1", "B": "VALUE2", "C": 1},
    {"A":"VALUE3", "B": "VALUE4", "C": 2},
    {"A":"VALUE5", "B": "VALUE6", "C": 3}]}
'

--SET @JSON = JSON_MODIFY(@JSON, '$.TMP.A', 'JEJE')
INSERT INTO @jsontable (a,b,c)
SELECT * FROM OPENJSON(@JSON, '$.TMP') WITH ( A NCHAR(10), B NCHAR(10), C INT )

UPDATE @jsontable 
SET a = 'JEJE' 

SELECT * 
FROM @jsontable

Alternativ 2:du kan manipulera JSON-komponenterna, men du måste skicka indexet till funktionen.

DECLARE @JSON NVARCHAR(MAX)
SET @JSON = 
N'{
"A":1,
"TMP": [    
    {"A":"VALUE1", "B": "VALUE2", "C": 1},
    {"A":"VALUE3", "B": "VALUE4", "C": 2},
    {"A":"VALUE5", "B": "VALUE6", "C": 3}]}
'

SET @JSON = JSON_MODIFY(@JSON, '$.TMP[0].A', 'JEJE')
SET @JSON = JSON_MODIFY(@JSON, '$.TMP[1].A', 'JEJE')
SET @JSON = JSON_MODIFY(@JSON, '$.TMP[2].A', 'JEJE')

SELECT * FROM OPENJSON(@JSON, '$.TMP') WITH ( A NCHAR(10), B NCHAR(10), C INT )


  1. Komplett guide för att åtgärda SQL Database Error 5243

  2. Sekvens vs identitet

  3. Oracle-sekvens som börjar med 2 istället för 1

  4. oracle jdbc drivrutin version galenskap