출처 : http://laigo.kr/723
SQL Server 2012 에서 XML 문서를 테이블에 Bulk Insert 하는 방법과 XQuery 를 사용하여 XML 데이터를 검색하는 몇 가지 예제를 아래와 같이 정리하였습니다.
1. XML 원본 문서를 테이블에 Bulk Insert 하는 방법
GO
USE XMLDB
GO
CREATE TABLE TBL_XML (
ID INT IDENTITY PRIMARY KEY,
XMLDATA XML
)
GO
INSERT INTO TBL_XML(XMLDATA)
SELECT * FROM OPENROWSET (
BULK 'D:\SQL\BOOKS.XML', SINGLE_BLOB) AS x;
2. XQuery 를 사용하여 XML 데이터 검색 예제
ID INT IDENTITY PRIMARY KEY,
XMLDATA XML
)
GO
INSERT INTO TBL_XQUERY VALUES ('
<CATALOG>
<book id="bk101">
<author>Gambardella, Matthew</author>
<title>XML Developer''s Guide</title>
<genre>Computer</genre>
<price>44.95</price>
<publish_date>2000-10-01</publish_date>
<description>An in-depth look at creating applications with XML.</description>
</book>
</CATALOG>
')
INSERT INTO TBL_XQUERY VALUES ('
<CATALOG>
<book id="bk102">
<author>Ralls, Kim</author>
<title>Midnight Rain</title>
<genre>Fantasy</genre>
<price>5.95</price>
<publish_date>2000-12-16</publish_date>
<description>A former architect battles corporate zombies, n evil sorceress, and her own childhood to become queen of the world.</description>
</book>
</CATALOG>
')
INSERT INTO TBL_XQUERY VALUES ('
<CATALOG>
<book id="bk103">
<author>Corets, Eva</author>
<title>Maeve Ascendant</title>
<genre>Fantasy</genre>
<price>5.95</price>
<publish_date>2000-11-17</publish_date>
<description>After the collapse of a nanotechnology society in England, the young survivors lay the foundation for a new society.</description>
</book>
</CATALOG>
')
SELECT XMLDATA.query('/CATALOG/book')
FROM TBL_XQUERY
WHERE ID = 2
/*
<book id="bk102">
<author>Ralls, Kim</author>
<title>Midnight Rain</title>
<genre>Fantasy</genre>
<price>5.95</price>
<publish_date>2000-12-16</publish_date>
<description>A former architect battles corporate zombies, n evil sorceress, and her own childhood to become queen of the world.</description>
</book>
*/
SELECT XMLDATA.value ( '(/CATALOG/book/@id)[1]', 'char(5)' ) AS 'Book id'
FROM TBL_XQUERY
/*
bk101
bk102
bk103
*/
SELECT XMLDATA
FROM TBL_XQUERY
WHERE XMLDATA.exist('/CATALOG/book[@id="bk103"]') = 1
/*
<CATALOG>
<book id="bk103">
<author>Corets, Eva</author>
<title>Maeve Ascendant</title>
<genre>Fantasy</genre>
<price>5.95</price>
<publish_date>2000-11-17</publish_date>
<description>After the collapse of a nanotechnology society in England, the young survivors lay the foundation for a new society.</description>
</book>
</CATALOG>
*/
SELECT
nCol.value('@id', 'char(5)') AS 'Book id',
nCol.value('(author)[1]', 'varchar(10)') AS author,
nCol.value('(title)[1]', 'varchar(50)') AS title,
nCol.value('(genre)[1]', 'varchar(10)') AS genre
FROM TBL_XQUERY
CROSS APPLY XMLDATA.nodes('/CATALOG/book') AS nTbl(nCol)
ORDER BY ID
/*
bk101 Gambardell XML Developer's Guide Computer
bk102 Ralls, Kim Midnight Rain Fantasy
bk103 Corets, Ev Maeve Ascendant Fantasy
*/
[참고자료]
Examples of Bulk Import and Export of XML Documents (SQL Server)
http://msdn.microsoft.com/en-us/library/ms191184.aspx
XQuery 언어 참조(SQL Server)
http://msdn.microsoft.com/ko-kr/library/ms189075.aspx
'DataBase' 카테고리의 다른 글
특정 컬럼명을 사용하는 모든 테이블 검색하는 쿼리 (0) | 2013.04.15 |
---|---|
MSSQL-XQuery에 대해서... (0) | 2013.03.08 |
NoSQL은 생각보다 쓸만하지 않다. (0) | 2012.09.26 |
MSSQL 2005 메모리 관리 (0) | 2012.08.09 |
MS-SQL 특정 테이블 데이터를 백업/복구 (0) | 2012.08.07 |