2

需要一点帮助。我收到一个类似这样的 xml 文件:

<?xml version="1.0" encoding="utf-16"?>
<dc:GRANTEE xsi:schemaLocation="http://www.blahblahblah.com/FullSchema test.xsd " xmlns:dc="http://www.blahblahblah.com/FullSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <RPGID>90CU0024</RPGID>
    <PLANID>01</PLANID>
    <CASE>
        <CASEID>100001</CASEID>
        <RPGID>90CU0024</RPGID>
        <FILE_O>2008-02-08T00:00:00</FILE_O>
        <ADULT>
            <ADULTID>100001A1</ADULTID>
            <CASEID>100001</CASEID>
            <APRIMARY>1</APRIMARY>
            <ARLTNSHP>BM</ARLTNSHP>
            <ADOB>1978-12-03T00:00:00</ADOB>
            <ARACAI>1</ARACAI>
            <ASEX>2</ASEX>
            <SATX>
                <SATXID>MD2120378</SATXID>
                <ADULTID>100001A1</ADULTID>
                <SAASSESS>2008-02-22T00:00:00</SAASSESS>
                <PUBPRVTX>1</PUBPRVTX>
                <TXADMIT>2008-02-23T00:00:00</TXADMIT>
                <TXSET>5</TXSET>
            </SATX>
        </ADULT>
        <CHILD>
            <CHILDID>100001C1</CHILDID>
            <CASEID>100001</CASEID>
            <CINDEX>1</CINDEX>
            <CHBDATE>2008-02-05T00:00:00</CHBDATE>
            <CHSEX>1</CHSEX>
            <CHRACAI>0</CHRACAI>
            <MALTX>
                <MALTXID>10000023</MALTXID>
                <CHILDID>100001C1</CHILDID>
                <RPTDT>2008-02-05T00:00:00</RPTDT>
                <CHMAL1>2</CHMAL1>
             </MALTX>
         </CHILD>
    </CASE>

我需要做的是导入它并将其切碎到带有存储过程的表中。除了在线书籍中的示例的一般反刍之外,我一直找不到任何东西,呃,在线。我需要的是一些语法演练,它显示了如何批量插入文件(使用 OPENROWSET?),然后获取所有数据并将其拆分到匹配的表中,同时维护键。看起来应该很容易,但参考资料却很难获得。如果需要,我也可以访问模式并且也可以进行注释。

有人有好的参考吗?

4

1 回答 1

1

您可以使用带有 RAW 关键字的 BULK INSERT 语句将数据加载到具有单列的表中。它会将整个文档放在一行中。然后查询表并将数据放入数据类型为 XML 的变量中。

这篇博客文章展示了如何从 XML 文档中获取数据。

于 2009-01-06T08:41:47.750 回答