> 데이터 베이스 > MySQL 튜토리얼 > SQL Server의 XML 열 내에서 특정 값을 쿼리하는 방법은 무엇입니까?

SQL Server의 XML 열 내에서 특정 값을 쿼리하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-13 12:35:13
원래의
633명이 탐색했습니다.

How to Query for Specific Values within an XML Column in SQL Server?

SQL Server의 XML 열에서 데이터 추출

SQL Server 내의 XML 데이터에서 특정 값을 효율적으로 검색하는 것은 데이터 분석에 매우 중요합니다. 이 가이드에서는 XML 열에 있는 특정 값을 쿼리하는 방법을 보여줍니다.

사용자 역할을 나타내는 XML을 저장하는 "역할"이라는 XML 열을 생각해 보세요. 샘플 XML 조각은 다음과 같습니다.

<code class="language-xml"><root><role>Alpha</role><role>Beta</role><role>Gamma</role></root></code>
로그인 후 복사

특정 역할(예: "Gamma")이 포함된 모든 행을 찾으려면 다음 T-SQL 쿼리를 사용하세요.

<code class="language-sql">SELECT
  Roles.value('(/root/role)[1]', 'varchar(max)')
FROM
  MyTable
WHERE
  Roles.value('(/root/role)[1]', 'varchar(max)') LIKE 'Gamma';</code>
로그인 후 복사

이 쿼리는 value() 함수를 사용하여 첫 번째 역할 이름을 추출하고 부분 일치에 LIKE을 사용합니다. 여기서는 "역할"이 XML 데이터 유형이라고 가정합니다. 다른 데이터 유형은 먼저 XML로 변환해야 합니다.

XML 속성 액세스

XML 요소에서 특정 속성을 쿼리해야 하는 경우 value() 함수는 도구로 유지되지만 XPath 표현식은 변경됩니다. 예를 들어 다음 속성이 포함된 XML을 생각해 보세요.

<code class="language-xml"><utilities.codesystems.codesystemcodes code="0001F" codesystem="2" ... /></code>
로그인 후 복사

"codesystem" 속성 값('2')을 검색하려면 다음을 사용하세요.

<code class="language-sql">SELECT
  CAST([data] AS XML).value('(/Utilities.CodeSystems.CodeSystemCodes/@codesystem)[1]', 'varchar(max)')
FROM
  [dbo].[CodeSystemCodes_data]
WHERE
  CAST([data] AS XML).value('(/Utilities.CodeSystems.CodeSystemCodes/@codesystem)[1]', 'varchar(max)') = '2';</code>
로그인 후 복사

고급 XML 쿼리

중첩된 XML 구조를 처리하거나 여러 역할 요소를 반복하는 등 더 복잡한 시나리오의 경우 XML 평면화 및 CROSS APPLY과 같은 기술을 살펴보세요. 이러한 방법에 대한 자세한 지침은 고급 SQL Server XML 설명서를 참조하세요.

위 내용은 SQL Server의 XML 열 내에서 특정 값을 쿼리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿