>  기사  >  데이터 베이스  >  SQL Server(T-SQL)에서 JSON 키의 이름을 바꾸는 방법은 무엇입니까?

SQL Server(T-SQL)에서 JSON 키의 이름을 바꾸는 방법은 무엇입니까?

藏色散人
藏色散人원래의
2019-04-03 13:52:102667검색

JSON_MODIFY() 함수를 사용하여 SQL Server에서 JSON 문서를 수정했다면 키/값의 <code>값을 수정하는 데 사용될 수 있습니다. 속성 > 섹션. 하지만 key 부분도 수정할 수 있다는 사실을 알고 계셨나요? JSON_MODIFY()函数来修改SQL Server中的JSON文档,那么你可能习惯于修改key/value属性的value部分。但是你知道你也可以修改key部分吗?

SQL Server(T-SQL)에서 JSON 키의 이름을 바꾸는 방법은 무엇입니까?

这样做的诀窍是将value复制到一个新键,然后删除旧键。

这里有一个基本的例子来说明我的意思。

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

-- 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,&#39;$.Handle&#39;, JSON_VALUE(@data,&#39;$.Name&#39;)),
  &#39;$.Name&#39;,
  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)=&#39;{"Residents":768}&#39;

-- 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,&#39;$.Population&#39;, CAST(JSON_VALUE(@data,&#39;$.Residents&#39;) AS int)),
  &#39;$.Residents&#39;,
  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)=&#39;{"Residents": 768}&#39;

-- 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,&#39;$.Population&#39;, JSON_VALUE(@data,&#39;$.Residents&#39;)),
  &#39;$.Residents&#39;,
  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)=&#39;{"Population":68}&#39;

-- 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,&#39;$."Average IQ"&#39;, CAST(JSON_VALUE(@data,&#39;$.Population&#39;) AS int)),
  &#39;$.Population&#39;,
  NULL
 )
-- Print the new JSON
PRINT @data

结果:

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

嵌套的属性

如果属性是嵌套的,则没有问题。只需使用点符号来引用它。

DECLARE @data NVARCHAR(4000)
SET @data=N&#39;{  
    "Suspect": {    
       "Name": "Homer Simpson",  
       "Hobbies": ["Eating", "Sleeping", "Base Jumping"]  
    }
 }&#39;
PRINT @data
SET @data=
  JSON_MODIFY(
    JSON_MODIFY(@data,&#39;$.Suspect.Qualifications&#39;, JSON_QUERY(@data,&#39;$.Suspect.Hobbies&#39;)),
   &#39;$.Suspect.Hobbies&#39;,
   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(T-SQL)에서 JSON 키의 이름을 바꾸는 방법은 무엇입니까?

이 작업을 수행하는 방법은 값을 새 키에 복사한 다음 이전 키를 삭제하는 것입니다. 다음은 제가 의미하는 바에 대한 기본적인 예입니다. rrreee결과:

rrreee🎜이렇게 하면 원래 키/값 쌍이 인쇄된 다음 새 키/값 쌍이 인쇄됩니다. 🎜🎜키의 "이름을 바꿨다"고 말할 수 있지만 실제로는 새 키를 만들고 기존 값을 해당 새 키에 복사한 다음 이전 키를 NULL로 설정하여 삭제했습니다. 🎜🎜이 예에서는 JSON_VALUE() 함수를 사용하여 값을 추출합니다. 🎜🎜🎜🎜데이터를 새 키에 복사할 때는 주의가 필요합니다. 기본적으로 SQL Server에서는 이를 큰따옴표로 묶습니다. 이것은 당신이 원하는 것일 수도 있고 아닐 수도 있습니다. 🎜🎜그러나 숫자 값을 복사하는 경우 해당 값이 여전히 숫자 값(즉, 큰따옴표 없이)이기를 원할 것입니다. 이 경우 CAST() 함수를 사용하여 숫자 데이터 유형으로 변환해야 합니다. 예는 다음과 같습니다.
🎜rrreee🎜결과:
🎜rrreee🎜따라서 결과는 숫자입니다. 🎜🎜이 예에서 CAST() 함수를 제거하면 결과는 다음과 같습니다. 🎜rrreee🎜결과:
🎜rrreee🎜따라서 이 경우 키 이름만 바꾸는 것이 아닙니다. , 또한 (JSON) 데이터 유형을 숫자에서 문자열로 변경했습니다. 🎜🎜참고, JSON은 다양한 숫자 유형을 구분하지 않습니다. 숫자 유형은 숫자 하나만 있습니다.
🎜🎜키 키 및 공백
🎜🎜이 경우 기존 키의 이름을 공백이 포함된 새 키로 변경했습니다(공백으로 구분된 두 단어로 구성됨). 🎜🎜새 키에는 공백이 포함되어 있으므로 키를 큰따옴표로 묶어야 합니다. 이렇게 하지 않으면 오류가 발생합니다.
🎜rrreee🎜결과:
🎜rrreee🎜중첩 속성🎜🎜속성이 중첩되면 문제가 없습니다. 참조하려면 점 표기법을 사용하세요.
🎜rrreee🎜결과:
🎜rrreee🎜또한 이 예에서는 이전처럼 를 사용하는 대신 <code>JSON_QUERY() 함수를 사용하여 값을 추출하는 것을 볼 수 있습니다. 예 >JSON_VALUE(). 🎜🎜이 경우에는 배열을 추출하고 있는데 JSON_VALUE()는 전체 배열을 추출할 수 없기 때문입니다(배열에서 스칼라 값만 추출할 수 있음). 반면, JSON_QUERY() 함수는 객체와 배열을 추출하지만 스칼라 값은 추출하지 않습니다. 🎜🎜관련 권장 사항: "🎜SQL Tutorial🎜" "🎜MySQL Tutorial🎜"🎜

위 내용은 SQL Server(T-SQL)에서 JSON 키의 이름을 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.