Vin*_*ith 8 ssis sql-server-2005
大家好我是SSIS的新手,我想读一个特定文件夹中的一堆xml文件.我想读取xml文件并在数据库表中输出数据.但是我对从哪里开始有点困惑.有人能指出我正确的方向吗?我在互联网上进行了搜索,但所有教程似乎都涵盖了通过txt文件循环而不是xml文件.我将使用sql server 2005,如果这有任何区别.
非常感谢 :)
小智 25
这是一个可能的选项,演示如何将具有相同定义的多个XML文件加载到SQL Server表中.该示例使用SQL Server 2008 R2和SSIS 2008 R2.此处显示的示例在组件Data Flow Task的帮助下使用SSIS将三个XML文件加载到SQL表中XML Source.
分步过程:
dbo.Items使用SQL Scripts部分下给出的脚本创建一个名为的表.Items.xsd 在文件夹路径C:\ temp\xsd中命名的XSD文件.Items_1.xml,Items_2.xml并Items_3.xml在文件夹路径C:\ temp\xml中创建.FileExtension,FilePath与FolderPath如图截图#1.SQLServer连接到SQL Server实例的OLE DB连接,如屏幕截图#2所示.Control Flow选项卡上,将a Foreach loop container和a Data Flow Task放在Foreach循环容器中,如屏幕截图#3所示.Foreach Loop container如屏幕截图#4和#5所示.Data Flow Task以导航到Data Flow选项卡.放置一个XML Source组件,OLE DB Destination如屏幕截图#6所示.XML Source如屏幕截图#7和#8所示.将从变量FilePath中检索XML文件路径.该变量将由Foreach Loop container.填充.OLE DB Destination如屏幕截图#9和#10所示.dbo.Items中的数据现在包含三个XML文件中的数据.希望有所帮助.
SQL脚本:
CREATE TABLE [dbo].[Items](
[Id] [int] IDENTITY(1,1) NOT NULL,
[ItemNumber] [nvarchar](50) NOT NULL,
[ItemName] [nvarchar](60) NOT NULL,
[Price] [numeric](18, 2) NOT NULL,
CONSTRAINT [PK_Items] PRIMARY KEY CLUSTERED ([Id] ASC)) ON [PRIMARY]
GO
Run Code Online (Sandbox Code Playgroud)
XSD文件
<xsd:schema xmlns:schema="ItemsXSDSchema" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:sqltypes="http://schemas.microsoft.com/sqlserver/2004/sqltypes" targetNamespace="ItemsXSDSchema" elementFormDefault="qualified">
<xsd:import namespace="http://schemas.microsoft.com/sqlserver/2004/sqltypes" schemaLocation="http://schemas.microsoft.com/sqlserver/2004/sqltypes/sqltypes.xsd" />
<xsd:element name="Items">
<xsd:complexType>
<xsd:sequence>
<xsd:element minOccurs="0" maxOccurs="unbounded" name="Item">
<xsd:complexType>
<xsd:sequence>
<xsd:element name="Id" type="sqltypes:int" />
<xsd:element name="ItemNumber">
<xsd:simpleType>
<xsd:restriction base="sqltypes:nvarchar" sqltypes:localeId="1033" sqltypes:sqlCompareOptions="IgnoreCase IgnoreKanaType IgnoreWidth" sqltypes:sqlSortId="52">
<xsd:maxLength value="20" />
</xsd:restriction>
</xsd:simpleType>
</xsd:element>
<xsd:element name="ItemName">
<xsd:simpleType>
<xsd:restriction base="sqltypes:nvarchar" sqltypes:localeId="1033" sqltypes:sqlCompareOptions="IgnoreCase IgnoreKanaType IgnoreWidth" sqltypes:sqlSortId="52">
<xsd:maxLength value="60" />
</xsd:restriction>
</xsd:simpleType>
</xsd:element>
<xsd:element name="Price">
<xsd:simpleType>
<xsd:restriction base="sqltypes:numeric">
<xsd:totalDigits value="18" />
<xsd:fractionDigits value="2" />
</xsd:restriction>
</xsd:simpleType>
</xsd:element>
</xsd:sequence>
</xsd:complexType>
</xsd:element>
</xsd:sequence>
</xsd:complexType>
</xsd:element>
</xsd:schema>
Run Code Online (Sandbox Code Playgroud)
XML文件
Items_1.xml
<?xml version="1.0"?>
<Items xmlns="ItemsXSDSchema">
<Item>
<Id>1</Id>
<ItemNumber>I2345343</ItemNumber>
<ItemName>Monitor</ItemName>
<Price>299.99</Price>
</Item>
</Items>
Run Code Online (Sandbox Code Playgroud)
Items_2.xml
<?xml version="1.0"?>
<Items xmlns="ItemsXSDSchema">
<Item>
<Id>1</Id>
<ItemNumber>J1231231</ItemNumber>
<ItemName>Mouse</ItemName>
<Price>29.99</Price>
</Item>
</Items>
Run Code Online (Sandbox Code Playgroud)
Items_3.xml
<?xml version="1.0"?>
<Items xmlns="ItemsXSDSchema">
<Item>
<Id>1</Id>
<ItemNumber>K0456212</ItemNumber>
<ItemName>Keyboard</ItemName>
<Price>49.99</Price>
</Item>
</Items>
Run Code Online (Sandbox Code Playgroud)
截图#1:

截图#2:

截图#3:

截图#4:

截图#5:

截图#6:

截图#7:

截图#8:

截图#9:

截图#10:

截图#11:

截图#12:

截图#13:

截图#14:
