SSIS常用的包—使用Bulk Insert执行任务
2010-09-19 11:45
302 查看
现在执行一个简单的bulk insert任务来练习刚才讨论的话题。首先创建一个名字为的SSIS项目。将Package.dtsx重新命名为BulkLoadZip.dtsx,如果弹出对话框提示是否重命名选择是。
首先新建文件夹C:\SSISDemos,将文件(/Files/tylerdonet/ZipCode.txt)放入这个文件夹内。然后在本地新建数据库,名字使用微软常用数据库的名字AdventureWorks,使用下面的代码新建一个表:
CREATE TABLE InsertContent (
ZipCode CHAR(5),
State CHAR(2),
ZipName VARCHAR(16)
)
新建一个SSIS项目,使用默认的package,将它重命名为BulkInsertTask.dtsx,切换到Control Flow界面,从工具栏中分别若放一个Execute SQL Task和Bulk Insert Task。双击打开Execute SQL Task的编辑界面,重新命名为Purge InsertContent table,在描述栏内填写自己想要的描述。
在Connection框创建localhost.AdventureWorks链接,在SQLStatemen框内填写下面的SQL语句:
DELETE FROM InsertContent
最终界面如下3-5,点击OK退出界面。
![](http://images.cnblogs.com/cnblogs_com/tylerdonet/3-5.gif)
从工具栏中拖放一个Bulk Insert Task,双击打开编辑界面,在Connection标签选择下拉列表中的<New connection……>新建一个OLE DB连接,在这个界面中新建一个连接,连接到本地服务器中AdventureWorks数据库中,界面如图3-3,在你自己的机器上信息可能有所不同,新建连接的界面如下。
![](http://images.cnblogs.com/cnblogs_com/tylerdonet/3-3.gif)
在Connection下拉列表框内现在可以看到刚才创建的链接,在目标表中选择表[AdventureWorks].[dbo].[InsertContent]。其他设置保持默认。行间隔符是{CR}{LF}(表示回车换行),列间隔符是制表符。在File框内再次选择<New connection…>创建一个连接,打开连接管理界面。在Usage Type下拉列表框中选择Existing File,这里选择C:\SSISDemos\ZipCode.txt。最终的界面如下图3-4
![](http://images.cnblogs.com/cnblogs_com/tylerdonet/3-4.gif)
下一步在Options标签界面内设置FirstRow为2。如果打开ZipCode.txt文件,可以发现在数据行之间有一个表头。设置FirstRow为2执行task的时候将忽略第一行的表头,从第二行开始插入。点击OK退户界面。
点击任务第一个Purge InsertContent Table底部的绿色箭头不放,拖动鼠标指向第二个任务Load Zip Codes,会有一条绿色带箭头连线。这个连线创建两个task之间的先后顺序,第一个task执行成功之后第二个任务才能执行。至此这个package已经完成了,点击保存并执行它。执行的时候首先使用SQL语句将表清空,然后bulk insert重新插入数据,执行成功之后,图标变成绿色的,如下图3-6
![](http://images.cnblogs.com/cnblogs_com/tylerdonet/%E6%9C%AA%E6%A0%87%E9%A2%98-1.gif)
点击Stop按钮可以中断执行。Bulk Insert的弊端是不能进行错误处理,它是一种要么全部,要么没有的任务。如果一行插入失败整个任务都将失败(通过设置最大错误数可以改变这种情况)。
首先新建文件夹C:\SSISDemos,将文件(/Files/tylerdonet/ZipCode.txt)放入这个文件夹内。然后在本地新建数据库,名字使用微软常用数据库的名字AdventureWorks,使用下面的代码新建一个表:
CREATE TABLE InsertContent (
ZipCode CHAR(5),
State CHAR(2),
ZipName VARCHAR(16)
)
新建一个SSIS项目,使用默认的package,将它重命名为BulkInsertTask.dtsx,切换到Control Flow界面,从工具栏中分别若放一个Execute SQL Task和Bulk Insert Task。双击打开Execute SQL Task的编辑界面,重新命名为Purge InsertContent table,在描述栏内填写自己想要的描述。
在Connection框创建localhost.AdventureWorks链接,在SQLStatemen框内填写下面的SQL语句:
DELETE FROM InsertContent
最终界面如下3-5,点击OK退出界面。
![](http://images.cnblogs.com/cnblogs_com/tylerdonet/3-5.gif)
从工具栏中拖放一个Bulk Insert Task,双击打开编辑界面,在Connection标签选择下拉列表中的<New connection……>新建一个OLE DB连接,在这个界面中新建一个连接,连接到本地服务器中AdventureWorks数据库中,界面如图3-3,在你自己的机器上信息可能有所不同,新建连接的界面如下。
![](http://images.cnblogs.com/cnblogs_com/tylerdonet/3-3.gif)
在Connection下拉列表框内现在可以看到刚才创建的链接,在目标表中选择表[AdventureWorks].[dbo].[InsertContent]。其他设置保持默认。行间隔符是{CR}{LF}(表示回车换行),列间隔符是制表符。在File框内再次选择<New connection…>创建一个连接,打开连接管理界面。在Usage Type下拉列表框中选择Existing File,这里选择C:\SSISDemos\ZipCode.txt。最终的界面如下图3-4
![](http://images.cnblogs.com/cnblogs_com/tylerdonet/3-4.gif)
下一步在Options标签界面内设置FirstRow为2。如果打开ZipCode.txt文件,可以发现在数据行之间有一个表头。设置FirstRow为2执行task的时候将忽略第一行的表头,从第二行开始插入。点击OK退户界面。
点击任务第一个Purge InsertContent Table底部的绿色箭头不放,拖动鼠标指向第二个任务Load Zip Codes,会有一条绿色带箭头连线。这个连线创建两个task之间的先后顺序,第一个task执行成功之后第二个任务才能执行。至此这个package已经完成了,点击保存并执行它。执行的时候首先使用SQL语句将表清空,然后bulk insert重新插入数据,执行成功之后,图标变成绿色的,如下图3-6
![](http://images.cnblogs.com/cnblogs_com/tylerdonet/%E6%9C%AA%E6%A0%87%E9%A2%98-1.gif)
点击Stop按钮可以中断执行。Bulk Insert的弊端是不能进行错误处理,它是一种要么全部,要么没有的任务。如果一行插入失败整个任务都将失败(通过设置最大错误数可以改变这种情况)。
相关文章推荐
- SSIS常用的包—使用Bulk Insert执行任务
- 3.4 使用Bulk Insert和Execute SQL任务
- SSIS常用的包—XML任务,SQL分析服务执行DDL和Processing任务
- SSIS常用的包—执行程序包任务
- SSIS常用的包—大量插入任务(Bulk Insert task)
- SSIS常用的包—执行任务
- SSIS常用的包—执行任务
- SSIS常用的包—执行程序包任务
- SSIS常用的包—大量插入任务(Bulk Insert task)
- PHP计划任务:如何使用Linux的Crontab执行PHP脚本
- Java 定时器的使用:每天定时执行任务
- PHP计划任务:如何使用Linux的Crontab执行PHP脚本
- SSIS常用的包—数据流任务
- SSIS常用的包—发送Email任务
- 使用 链接服务器执行SELECT、UPDATE、INSERT 或 DELETE 及其它命令
- 通过SSIS实现Oracle与Sqlserver数据库间的数据同步,并定时执行同步任务
- 使用Swing Worker线程 --执行后台任务的新方法
- 3.11、BI之SSIS之执行SQL任务
- 使用Async执行下载任务
- Global中使用线程隔时执行一项任务