[sql] XML 데이터 타입

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

위의 쿼리는 MyTableData 열에서 Price 값이 50보다 큰 <Book> 요소를 검색하여 반환합니다.

마무리

XML 데이터 타입은 SQL에서 XML 데이터를 보다 쉽게 처리하고 검색할 수 있도록 도와줍니다. 이를 통해 XML 데이터를 효율적으로 활용하여 다양한 기능을 구현할 수 있습니다.

참고 문서: