在SQL Server中重命名JSON密钥的方法

发布时间:2020-08-26 11:12:14 作者:小新
来源:亿速云 阅读:169

小编给大家分享一下在SQL Server中重命名JSON密钥的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

如果你一直使用JSON_MODIFY()函数来修改SQL Server中的JSON文档,那么你可能习惯于修改key/value属性的value部分。但是你知道你也可以修改key部分吗?

在SQL Server中重命名JSON密钥的方法

这样做的诀窍是将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 Server中重命名JSON密钥的方法的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. 在Linux上使用环境变量配置SQL Server设置
  2. 怎么加密sql中的表

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sql json

上一篇:python循环结构中如何使用else

下一篇:什么是python缩进

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》