XML은 많은 데이터를 계층 구조로 저장하고 전송하는 데 사용되는 인기있는 데이터 포맷입니다. SQL에서는 XML 데이터를 효율적으로 처리하기 위해 XML 데이터 타입을 제공합니다. XML 데이터 타입은 SQL Server, Oracle 등 다양한 데이터베이스 시스템에서 사용할 수 있습니다.
XML 데이터 타입 정의하기
XML 데이터 타입을 사용하려면 해당 열을 XML 타입으로 정의해야 합니다. 다음은 SQL Server에서 XML 데이터 타입을 정의하는 예시입니다.
CREATE TABLE MyTable
(
ID INT PRIMARY KEY,
Data XML
)
위의 예시에서 Data
열은 XML 데이터를 저장하기 위한 열로 정의되었습니다.
XML 데이터 쿼리하기
XML 데이터 타입을 사용하면 XML 데이터 내에 포함된 정보를 쿼리할 수 있습니다. 다음은 XML 데이터에서 특정 요소를 추출하는 예시입니다.
SELECT Data.value('(Book/Title)[1]', 'nvarchar(100)') AS Title
FROM MyTable
WHERE ID = 1
위의 쿼리는 MyTable
에서 ID
가 1인 행의 Data
열에서 첫 번째 <Book>
요소의 <Title>
값을 추출하여 반환합니다.
XML 데이터 조작하기
XML 데이터를 조작하기 위해 SQL에서는 XML 데이터 타입과 관련된 함수와 메소드를 제공합니다. 다음은 XML 데이터에 새로운 요소를 추가하는 예시입니다.
UPDATE MyTable
SET Data.modify('
insert <Author>John Doe</Author>
as first
into (/Book)[1]
')
WHERE ID = 1
위의 예시는 MyTable
에서 ID
가 1인 행의 Data
열에 <Author>
요소를 첫 번째 <Book>
요소 안에 추가합니다.
XML 데이터 검색하기
XML 데이터 타입을 사용하여 해당 데이터에서 원하는 정보를 검색하는 것도 가능합니다. 다음은 XML 데이터에서 특정 요소를 검색하는 예시입니다.
SELECT *
FROM MyTable
WHERE Data.exist('/Books/Book[Price > 50]') = 1
위의 쿼리는 MyTable
의 Data
열에서 Price
값이 50보다 큰 <Book>
요소를 검색하여 반환합니다.
마무리
XML 데이터 타입은 SQL에서 XML 데이터를 보다 쉽게 처리하고 검색할 수 있도록 도와줍니다. 이를 통해 XML 데이터를 효율적으로 활용하여 다양한 기능을 구현할 수 있습니다.
참고 문서: