小編給大家分享一下在SQL Server中重命名JSON密鑰的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創新互聯公司是專業的香格里拉網站建設公司,香格里拉接單;提供做網站、成都做網站,網頁設計,網站設計,建網站,PHP網站建設等專業做網站服務;采用PHP框架,可快速的進行香格里拉網站開發網頁制作和功能擴展;專業做搜索引擎喜愛的網站,專業的做網站團隊,希望更多企業前來合作!如果你一直使用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 Server中重命名JSON密鑰的方法的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯網站制作公司行業資訊頻道!
文章名稱:在SQLServer中重命名JSON密鑰的方法-創新互聯
轉載來源:http://www.yijiale78.com/article48/cdpehp.html
成都網站建設公司_創新互聯,為您提供營銷型網站建設、云服務器、微信公眾號、虛擬主機、企業網站制作、電子商務
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯