首页 >> 手游攻略

SSIS698

大家好,如果您还对SSIS698不太了解,没有关系,今天就由本站为大家分享SSIS698的知识,包括SSIS 包配置的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!

在商业智能解决方案中,SSIS工程有两种部署模式:工程部署(projectdeployment)和包部署(packagedeployment),默认是工程部署模式,在Package的管理上,工程部署模式是当前主流的部署模式,比包部署的更容易管理,也更容易对package进行调试和故障排除,而包部署模式是传统的部署模式在包部署模式中。在包部署模式中,SSIS引擎支持包配置(PackageConfiguration)功能,用户能够在Package运行时动态修改属性值。包配置是配置项的集合,每一个配置项(configurationitem)是一个属性/值对(property/valuepair)。用户向包配置中增加配置项,Package在运行时从包配置中获取属性值,对Package的执行进行编程控制,特别在批量管理Package的场景中,比如,批量修改Package的某一个公共变量的值,切换Package的测试和产品环境等,包配置十分有用。

一般情况下,包配置信息存储在SQLServer数据库中,用户能够配置的Package对象共有四种,分别是:

ConnectionManagers:Package的链接管理器(connectionmanagers);Executables:package的可执行组件;Propertites:package的properties;Variables:package的variables;

以上四种Package对象,都能够被参数化配置,这是SSIS能够把其属性值存储在包配置中,并能够在执行时应用属性的配置值的基础。

在执行Package时,SSISPackage首先读取包配置信息,将包配置中的属性值应用到Package中,然后执行package的可执行组件(executables);修改包配置中属性的值,将动态改变Package的执行上下文,例如,测试环境和产品环境的切换,修改链接管理器(ConnectionManager)的连接字符串的值,使package将运行结果同步到测试环境中;在测试环境中package运行无误后,再将其部署到Production环境中,如果使用包配置管理链接管理器的链接字符串,那么只需要修改包配置中ConnectionManager的连接字符串的值,而不需要对Package做任何修改。

一,切换到包部署模式SSISProject默认的部署模式是ProjectDeploymentModel,在解决方案的工程列表中选中工程,右击弹出快捷菜单,点击“ConverttoPackageDeploymentModel”,将Project的部署模式转换为包部署模式。

切换到包部署模式之后,Project名称之后显示模式名称:(packagedeploymentmodel)

二,设计Package

向Package中添加一个变量(VarCode)和一个ExecuteSQLTask组件,在Task组件中执行如下的TSQL语句脚本,“?”代表参数,映射到变量(VarCode),把变量的值插入到指定的表中

insertintodbo.dt_testnvalues(1,?,'a')

1,配置Task组件执行的TSQL语句

2,配置Task组件的参数映射

三,启用包配置

1,打开包配置向导

点击SSIS菜单,选择“packageconfigurations”,或者在Package的“ControlFlow”面板的空白处右击,弹出快捷菜单,选中“packageconfigurations",都能打开包配置向导。

2,启用包配置

勾选“Enablepackageconfigurations”复选框,为当前Package启用包配置功能

3,添加包配置

在”PackageConfigurationsOrganizer“中,点击Add按钮,在配置类型(ConfigurationType)列表中选择SQLServer,这意味着,Package使用SQLServer数据库来存储包配置的信息,同时,Package从SQLServer数据库中读取配置项信息。

为了存储包配置信息,必须设置SQLServer数据库及配置表,选中“specifyconfigurationsettingsdirectly”,指定SQLServer类型的配置设置:链接(Connection),配置表(Configurationtable)和配置过滤器(ConfigurationFilter)。

4,配置表(ConfigurationTable)

在Package执行时,如果指定SQLServer数据库中没有配置表,那么Package会自动创建配置表,默认情况下,SSIS用于创建配置表的脚本是:

CREATETABLE[dbo].[SSISConfigurations]n(nConfigurationFilterNVARCHAR(255)NOTNULL,nConfiguredValueNVARCHAR(255)NULL,nPackagePathNVARCHAR(255)NOTNULL,nConfiguredValueTypeNVARCHAR(20)NOTNULLn)

配置表各个字段的含义是:

ConfigurationFilter:用于唯一标识配置集的过滤器,每一个配置集都是属性/值对(property/valuespair)的集合,每个Package只能设置一个ConfigurationFilter,拥有相同的ConfigurationFilter的Packages,其配置集相同,共享相同的配置信息;ConfigurationValue:配置属性的值,用于更新配置属性值;PackagePath:配置属性的路径,包含配置属性及其路径信息,例如,"\Package.Variables[User::VarCode].Properties[Values]"ConfiguredValueType:配置属性的数据类型;

设置配置表的链接和配置集过滤器(Configurationfilter):

Connection:用于设置访问configurationtable的链接;ConfigurationTable:指定配置表的名字(tablename);Configurationfilter:当多个Package共用一个ConfigurationTable时,需要为每个Package设置configurationfilter,如果filter相同,表明package使用相同的配置数据;如果某些Package有特殊的配置信息,可以为其设置不同的filter。

四,设置配置项(configurationitem)

将变量VarCode的值配置到包配置中,这意味着,把变量VarCode的值存储在[dbo].[SSISConfigurations]中,Package在执行时读取这个值,并把读取到的值作为变量VarCode的值,供Task组件使用。

五,查看配置信息

当配置类型为SQLServer时,包配置信息存储在SQLServer数据库中,默认的配置表名是[dbo].[SSISConfigurations]

select*nfrom[dbo].[SSISConfigurations]

六,执行package,查看执行的结果

1,使用默认值执行Package,查看Task组件执行的结果

2,修改[dbo].[SSISConfigurations]中的ConfiguredValue,再次运行package,查看Task组件执行的结果

update[dbo].[SSISConfigurations]nsetConfiguredValue=2nwhereConfigurationFilter='configuration_parameter_value'

SSIS698和SSIS 包配置的问题分享结束啦,以上的文章解决了您的问题吗?欢迎您下次再来哦!



本文由欣欣吧手游攻略栏目发布,感谢您对欣欣吧的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人站长或者朋友圈,但转载请说明文章出处“SSIS698

标签:
soe-472
« 上一篇 2023-10-09