在以前的dts中,在包的开发、测试、发布迁移过程中有很多问题,典型的问题是你必须手动的确定包中的所有连接都指向一个实际存在的物理服务器
幸运的是,现在在ssis中提供了这种问题的解决方案,那就是包配置
包配置是一个动态改变你的ssis对象和连接属性的一种机制,它把这些动态可以改变的信息保存在包的外部,有下面几种方法存储这些值并将其传送到包中:
xml文件
环境变量
注册表键值
父包变量
下面我们将举例使用xml文件存储这些值
这个例子我们将会把一个文本文件导入到数据库的表中,并可以动态配置数据库的位置来源
首先开始我们的包的建立:
假设存在一文本文件 personage.txt,内容如下:
1,joe bloggs,27
2,mary smith,26
3,fred jones,28
目标表为dbo.personage,使用下面代码建立
create table [dbo].[personage](
[personagekey] [int] null,
[person] [varchar](35) null,
[personage] [int] null
) on [primary]
go
下面开始拖曳组件到控制流面板
。一个execute sql task组件,命名为truncate destination. 其 sql 命令为 truncate table dbo.personage.
。一个数据流组件,命名为import file.
。然后把2者关联起来
下面开始设计【import file】数据流任务
。一个 flat file connection 组件指向personage.txt文件
。一个 ole db connection 组件指向存在dbo.personage表的数据库 ,然后配置列的属性,使表跟文件对应起来
到现在为止,已经成功的建立了包
设置包配置
现在开始设置包配置,这是非常简单的且具有很好的弹性
包配置使你能编辑你的包的属性、变量、连接和你的控制流的其他属性,需要注意的是,你不能编辑你的数据流组件的属性
在菜单条上,单击dts, package configurations… 或者在控制流设计面板右键选择package configurations….
然后在包配置中允许包配置选择,并单击添加
在单击过后出现一个欢迎屏幕并让你选择配置类型,当前选择xml configuration file
然后键入配置文件名,如c:/packageconfigurations/environment.dtsconfig,单击下一步
然后在对象树浏览中选择connections.destination.properties的initialcatalog 和 servername属性,然后单击下一步
给你的配置一个名字,这样整个过程就完成了
这样你的包将在运行期间获得2个属性的值,你打开xml配置文件,你将看得这些你需要动态改变属性的当前值
现在,你可以非常容易的迁移包到另一个新的环境,而你只须改变你的包配置文件(c:/packageconfigurations/environment.dtsconfig)即可
新闻热点
疑难解答