旗下导航:搜·么
当前位置:网站首页 > MySQL教程 > 正文

如安在SQL Server中重命名JSON密钥(T-SQL)?【MySQL教程】,SQL,JSON

作者:搜教程发布时间:2019-12-01分类:MySQL教程浏览:68评论:0


导读:假如你一向运用JSON_MODIFY()函数来修正SQLServer中的JSON文档,那末你能够习惯于修正key/value属性的value部份。然则你晓得你也能够修...
假如你一向运用 JSON_MODIFY()函数来修正SQL Server中的JSON文档,那末你能够习惯于修正 key/value属性的 value部份。然则你晓得你也能够修正 key部份吗?

如许做的窍门是将value复制到一个新键,然后删除旧键。

这里有一个基础的例子来申明我的意义。

-- Declare a variable and assign some JSON to it
DECLARE @data NVARCHAR(50)='{"Name":"Homer"}'

-- Print the current JSON
PRINT @data

-- Rename the key (by copying the value to a new key, then deleting the old one)
SET @data=
 JSON_MODIFY(
  JSON_MODIFY(@data,'$.Handle', JSON_VALUE(@data,'$.Name')),
  '$.Name',
  NULL
 )
-- Print the new JSON
PRINT @data

效果:

{"Name":"Homer"}
{"Handle":"Homer"}

这将打印出原始的键/值对,然后是新的键/值对。

虽然我们能够说我们“重命名”了密钥,但实际上我们只是创建了一个新密钥,将现有值复制到该新密钥,然后将旧密钥设置为NULL来删除它。

在本例中,我们运用JSON_VALUE()函数来提取值。

数值

在将数据复制到新键时须要警惕。默许情况下,SQL Server将它括在双引号中。这多是你想要的,也能够不是。

然则,假如你复制一个数值,你能够愿望它仍然是一个数值(即没有双引号)。在本例中,须要运用CAST()函数将其转换为数值数据范例。这里有一个例子:

-- Declare a variable and assign some JSON to it
DECLARE @data NVARCHAR(50)='{"Residents":768}'

-- Print the current JSON
PRINT @data

-- Rename the key (by copying the value to a new key, then deleting the old one)
SET @data=
 JSON_MODIFY(
  JSON_MODIFY(@data,'$.Population', CAST(JSON_VALUE(@data,'$.Residents') AS int)),
  '$.Residents',
  NULL
 )
-- Print the new JSON
PRINT @data

效果:

{"Residents":768}
{"Population":768}

所以效果是一个数字。

假如我们从这个例子中删除CAST()函数,我们获得的效果是:

-- Declare a variable and assign some JSON to it
DECLARE @data NVARCHAR(50)='{"Residents": 768}'

-- Print the current JSON
PRINT @data

-- Rename the key (by copying the value to a new key, then deleting the old one)
SET @data=
 JSON_MODIFY(
  JSON_MODIFY(@data,'$.Population', JSON_VALUE(@data,'$.Residents')),
  '$.Residents',
  NULL
 )
-- Print the new JSON
PRINT @data

效果:

{"Residents": 768}
{"Population":"768"}

因而,在本例中,我们不仅重命名了键,还将(JSON)数据范例从数字更改成字符串。

注重,JSON不辨别差别的数字范例。它只要一个数字范例:number。

key键和空格

在本例中,我将一个现有键重命名为一个包括空格的新键(它由两个单词构成,用空格分开)。

由于新键包括空格,所以我须要用双引号括住键。假如不如许做,就会涌现毛病。

-- Declare a variable and assign some JSON to it
DECLARE @data NVARCHAR(50)='{"Population":68}'

-- Print the current JSON
PRINT @data

-- Rename the key (by copying the value to a new key, then deleting the old one)
SET @data=
 JSON_MODIFY(
  JSON_MODIFY(@data,'$."Average IQ"', CAST(JSON_VALUE(@data,'$.Population') AS int)),
  '$.Population',
  NULL
 )
-- Print the new JSON
PRINT @data

效果:

{"Population":68}
{"Average IQ":68}

嵌套的属性

假如属性是嵌套的,则没有题目。只需运用点标记来引用它。

DECLARE @data NVARCHAR(4000)
SET @data=N'{  
    "Suspect": {    
       "Name": "Homer Simpson",  
       "Hobbies": ["Eating", "Sleeping", "Base Jumping"]  
    }
 }'
PRINT @data
SET @data=
  JSON_MODIFY(
    JSON_MODIFY(@data,'$.Suspect.Qualifications', JSON_QUERY(@data,'$.Suspect.Hobbies')),
   '$.Suspect.Hobbies',
   NULL
  )
PRINT @data

效果:

{ 
"Suspect": { 
"Name": "Homer Simpson", 
"Hobbies": ["Eating", "Sleeping", "Base Jumping"] 
}
}
{ 
"Suspect": { 
"Name": "Homer Simpson" 
,"Qualifications":["Eating", "Sleeping", "Base Jumping"]}
}

你能够还注重到,这个示例运用JSON_QUERY()函数来提取值,而不是像前面的示例那样运用JSON_VALUE()

这是由于在本例中,我们正在提取一个数组,而JSON_VALUE()不能提取全部数组(它只能从数组中提取标量值)。另一方面,JSON_QUERY()函数提取对象和数组,但不提取标量值。

相干引荐:《SQL教程》《MySQL教程》

以上就是如安在SQL Server中重命名JSON密钥(T-SQL)?的细致内容,更多请关注ki4网别的相干文章!

标签:SQLJSON


欢迎 发表评论: