我們知道SQL Server 2005中增加了XML類型,也就是說在創建表的時候可以指定某一列爲XML類型,如:
CREATE TABLE customers
(
name VARCHAR(20) NOT NULL PRIMARY KEY,
description XML
)
那麼如何向XML類型的列中插入數據呢?
基本上有三種辦法:
1。直接使用字符串,如
INSERT INTO customers (feedName, feedXML) VALUES
(‘Ramon Liu’, ‘<description>rich customer</description>’)
2。使用FOR XML,如
GO
--declare xml type variable
DECLARE @xmlDoc XML
SET @xmlDoc =
(
SELECT Name, SalesYTD FROM Sales.SalesTerritory
FOR XML AUTO, ROOT ('territories'), ELEMENTS
)
INSERT INTO customers (name, description) VALUES
('Stanley', @xmlDoc)
3.使用OPENROWSET從文件中加載,如
GO
INSERT INTO customers (name, description)
SELECT 'Justin', xmlData FROM
(
SELECT * FROM OPENROWSET
(BULK 'd:/desc.xml', SINGLE_NCLOB)
AS xmlData
) AS feed (xmlData)
GO
SELECT * FROM customers
CREATE TABLE customers
(
name VARCHAR(20) NOT NULL PRIMARY KEY,
description XML
)
那麼如何向XML類型的列中插入數據呢?
基本上有三種辦法:
1。直接使用字符串,如
INSERT INTO customers (feedName, feedXML) VALUES
(‘Ramon Liu’, ‘<description>rich customer</description>’)
2。使用FOR XML,如
GO
--declare xml type variable
DECLARE @xmlDoc XML
SET @xmlDoc =
(
SELECT Name, SalesYTD FROM Sales.SalesTerritory
FOR XML AUTO, ROOT ('territories'), ELEMENTS
)
INSERT INTO customers (name, description) VALUES
('Stanley', @xmlDoc)
3.使用OPENROWSET從文件中加載,如
GO
INSERT INTO customers (name, description)
SELECT 'Justin', xmlData FROM
(
SELECT * FROM OPENROWSET
(BULK 'd:/desc.xml', SINGLE_NCLOB)
AS xmlData
) AS feed (xmlData)
GO
SELECT * FROM customers