欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

在SQLServer中重命名JSON密鑰的方法-創(chuàng)新互聯(lián)

小編給大家分享一下在SQL Server中重命名JSON密鑰的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司是專業(yè)的香格里拉網(wǎng)站建設(shè)公司,香格里拉接單;提供做網(wǎng)站、成都做網(wǎng)站,網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行香格里拉網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!

如果你一直使用JSON_MODIFY()函數(shù)來修改SQL Server中的JSON文檔,那么你可能習(xí)慣于修改key/value屬性的value部分。但是你知道你也可以修改key部分嗎?

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

這樣做的訣竅是將value復(fù)制到一個(gè)新鍵,然后刪除舊鍵。

這里有一個(gè)基本的例子來說明我的意思。

-- 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

結(jié)果:

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

這將打印出原始的鍵/值對,然后是新的鍵/值對。

雖然我們可以說我們“重命名”了密鑰,但實(shí)際上我們只是創(chuàng)建了一個(gè)新密鑰,將現(xiàn)有值復(fù)制到該新密鑰,然后將舊密鑰設(shè)置為NULL來刪除它。

在本例中,我們使用JSON_VALUE()函數(shù)來提取值。

數(shù)值

在將數(shù)據(jù)復(fù)制到新鍵時(shí)需要小心。默認(rèn)情況下,SQL Server將它括在雙引號(hào)中。這可能是你想要的,也可能不是。

但是,如果你復(fù)制一個(gè)數(shù)值,你可能希望它仍然是一個(gè)數(shù)值(即沒有雙引號(hào))。在本例中,需要使用CAST()函數(shù)將其轉(zhuǎn)換為數(shù)值數(shù)據(jù)類型。這里有一個(gè)例子:

-- 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

結(jié)果:

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

所以結(jié)果是一個(gè)數(shù)字。

如果我們從這個(gè)例子中刪除CAST()函數(shù),我們得到的結(jié)果是:

-- 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

結(jié)果:

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

因此,在本例中,我們不僅重命名了鍵,還將(JSON)數(shù)據(jù)類型從數(shù)字更改為字符串。

注意,JSON不區(qū)分不同的數(shù)字類型。它只有一個(gè)數(shù)字類型:number。

key鍵和空格

在本例中,我將一個(gè)現(xiàn)有鍵重命名為一個(gè)包含空格的新鍵(它由兩個(gè)單詞組成,用空格分隔)。

因?yàn)樾骆I包含空格,所以我需要用雙引號(hào)括住鍵。如果不這樣做,就會(huì)出現(xiàn)錯(cuò)誤。

-- 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

結(jié)果:

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

嵌套的屬性

如果屬性是嵌套的,則沒有問題。只需使用點(diǎn)符號(hào)來引用它。

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

結(jié)果:

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

你可能還注意到,這個(gè)示例使用JSON_QUERY()函數(shù)來提取值,而不是像前面的示例那樣使用JSON_VALUE()。

這是因?yàn)樵诒纠?,我們正在提取一個(gè)數(shù)組,而JSON_VALUE()不能提取整個(gè)數(shù)組(它只能從數(shù)組中提取標(biāo)量值)。另一方面,JSON_QUERY()函數(shù)提取對象和數(shù)組,但不提取標(biāo)量值。

以上是在SQL Server中重命名JSON密鑰的方法的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道!

文章名稱:在SQLServer中重命名JSON密鑰的方法-創(chuàng)新互聯(lián)
轉(zhuǎn)載來源:http://aaarwkj.com/article48/cdpehp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)、云服務(wù)器、微信公眾號(hào)虛擬主機(jī)、企業(yè)網(wǎng)站制作、電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
日韩区一区二在线视频| 人体艺术日韩色噜噜| 中文字幕有码精品在线| 亚洲国产成人午夜精品| 91欧美日韩在线观看视频| 麻豆片免费观看在线看| 国内午夜福利精品视频| 久久精品人妻麻豆尤物| 欧美激情三级一区二区| 国产高清不卡午夜福利| 亚洲成av在线免费不卡| 天天干夜夜操天天射| 欧美曰韩国内精品中文| 亚洲蜜桃精品一区二区三区| 给我搜亚洲免费播放黄色大片| 五月婷婷亚洲激情综合网| 激情综合五月激情综合| 中文字幕一区二区精品区| 欧美日韩国产精品高清| 91精品国产人妻女教师| 视频一区二区中文字幕日韩| 欧美日韩国产看片一区二区| 看看美女阴逼毛茸茸的| 夜色一区二区av人片| 99热这里只有精品欧美| 自拍偷拍亚洲另类激情| 日韩在线免费色视频| 毛片91成人在线播放| 蜜桃福利视频一区二区| 日本乱码一区二区三区在线观看 | 我要看国产一级内射片| 精品人妻区二区三区蜜桃| 高清免费国产日日操夜夜草| 久久精品噜噜噜成人av农村| 国产成人精品高清国产三级| 国产在线精品不卡一区| 动漫美女视频在线看黄| 色吊丝日韩在线观看| 婷婷中文字幕在线视频| 中文字幕乱码日韩一区| 久草尤物视频在线观看|