poo*_*oja 13 sql-server-2008 xml sql-server
如何读取 XML 文件并将 XML 中的数据存储到 SQL Server 2008 中的表中?
这个解析节点基于 XML。读取属性有所不同,但并不常见
我把它当作一个演示,其中包含 3 个略有不同的 XPath 查询
DECLARE @foo XML
SELECT @foo = N'
<harrys>
<harry>
<fish>0.015000000000</fish>
<bicycle>2008-10-31T00:00:00+01:00</bicycle>
<foo>ü</foo>
</harry>
<harry>
<fish>0.025000000000</fish>
<bicycle>2008-08-31T00:00:00+01:00</bicycle>
<foo>ä</foo>
</harry>
</harrys>
'
SELECT
CAST(CAST(y.item.query('data(fish)') AS varchar(30)) AS float),
CAST(LEFT(CAST(y.item.query('data(bicycle)') AS char(25)), 10) AS smalldatetime),
CAST(y.item.query('data(foo)') AS varchar(25))
FROM
@foo.nodes('/*') x(item)
CROSS APPLY
x.item.nodes('./*') AS y(item)
SELECT
CAST(CAST(x.item.query('data(fish)') AS varchar(30)) AS float),
CAST(LEFT(CAST(x.item.query('data(bicycle)') AS char(25)), 10) AS smalldatetime),
CAST(x.item.query('data(foo)') AS varchar(25))
FROM
@foo.nodes('harrys/harry') x(item)
SELECT
CAST(CAST(y.item.query('data(fish)') AS varchar(30)) AS float),
CAST(LEFT(CAST(y.item.query('data(bicycle)') AS char(25)), 10) AS smalldatetime),
CAST(y.item.query('data(foo)') AS varchar(25))
FROM
@foo.nodes('/harrys') x(item)
CROSS APPLY
x.item.nodes('./harry') AS y(item)
Run Code Online (Sandbox Code Playgroud)
我已经用上面的答案试过了。尝试一下,
XML:
<?xml version="1.0" encoding="utf-8" ?>
- <FundingSought xml:lang="en">
- <Fund>
<FundName>sdfdsfd</FundName>
<FundValue>1</FundValue>
</Fund>
- <Fund>
<FundName>dfdgfdg</FundName>
<FundValue>2</FundValue>
</Fund>
- <Fund>
<FundName>fghghh</FundName>
<FundValue>3</FundValue>
</Fund>
- <Fund>
<FundName>sdfdgg</FundName>
<FundValue>4</FundValue>
</Fund>
- <Fund>
<FundName>hgfhh</FundName>
<FundValue>5</FundValue>
</Fund>
- <Fund>
<FundName>fghgh</FundName>
<FundValue>6</FundValue>
</Fund>
- <Fund>
<FundName>ghhhh</FundName>
<FundValue>7</FundValue>
</Fund>
- <Fund>
<FundName>hfghh</FundName>
<FundValue>8</FundValue>
</Fund>
</FundingSought>
Run Code Online (Sandbox Code Playgroud)
查询语句:
CREATE TABLE #XmlImportTest(
xmlFileName VARCHAR(300) NOT NULL,
xml_data XML NOT NULL
)
GO
DECLARE @xmlFileName VARCHAR(300)
SELECT @xmlFileName = 'C:\FundingSought.xml'
--– dynamic sql is just so we can use @xmlFileName variable in OPENROWSET
EXEC('INSERT INTO #XmlImportTest(xmlFileName, xml_data)
SELECT ''' + @xmlFileName + ''', xmlData
FROM(
SELECT *
FROM OPENROWSET (BULK ''' + @xmlFileName + ''', SINGLE_BLOB) AS XMLDATA
) AS FileImport (XMLDATA)
')
GO
DECLARE @foo XML
SET @foo = (SELECT xml_data from #XmlImportTest)
SELECT
CAST(y.item.query('data(FundName)') AS varchar(30)),
CAST(y.item.query('data(FundValue)') AS char(25))
FROM
@foo.nodes('/*') x(item)
CROSS APPLY
x.item.nodes('./*') AS y(item)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
41653 次 |
| 最近记录: |