分享
 
 
 

SQL2005 SSIS-在脚本组件中访问数据连接

王朝mssql·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

在上文中我们知道了如何在脚本组件中访问包变量,但在其中访问数据连接应该怎么办呢?

通过查看DTS类的属性我们知道其有一个 Connections 属性,其对应的正是SSIS设计面板中连接管理器中连接的映射

比如我们在连接管理器中建立一个 ADO.NET 的连接,命名为 connect1

那么在组件代码中我们就可以通过下面2种方式访问这个连接,如下

Dts.Connections(0)

或者

Dts.Connections("connect1")

但是其并不是连接对象,不能直接作用于命令对象中,故需要强制转换为连接对象,如下代码:

Dim sqlConn As SqlConnection

sqlConn = CType(Dts.Connections(0).AcquireConnection(Nothing), SqlConnection)

需要注意,不能直接CType(Dts.Connections(0), SqlConnection),需要用该对象的AcquireConnection方法获得一个连接,再强制转换

好了,现在已经转换为连接对象,你可以使用如下代码再该连接中执行命令

Dim command As New SqlClient.SqlCommand

command.Connection = sqlConn

command.CommandType = CommandType.Text

command.CommandText = "你的命令"

command.ExecuteNonQuery()

command = Nothing

本来到此就应该结束此文了,但是可惜的是还要继续下去

上面提到的是在连接管理器中建立一个ADO.NET的连接,如果你建立一个OLE.DB的连接,在运行上面代码,你会得到下面错误:

Unable to cast COM object of type 'System.Data.OleDb.OleDbConnection' to class type ''.

Instances of types that represent COM components cannot be cast to types that do not represent COM components;

however they can be cast to interfaces as long as the underlying COM component supports QueryInterface calls for the IID of the interface.

上面的大概意思就是说,不能进行强制类型转换,当前对象没有提供这样的接口

明白了把,就是说不行,也就是说你建立的是OLE.DB连接,那么 AcquireConnection 方法返回的也是一个 OLE.DB的连接对象,你不能用SqlConnection去替代它

怎么办呢,解决方法有二

一是把OLE.DB连接对象的类型找出来,并引用上它,然后再用它强制转换,但是可惜的是我不知道怎么样才能。。。。;

二就是建立一个ADO.NET的连接好了,可是我又怕它是不是会比OLE.DB的连接处理速度要慢,所以之后通融一下了,代码如下

Public Class ScriptMain

Public Sub Main()

Dim command As New SqlClient.SqlCommand

Dim cn As New SqlClient.SqlConnection

MsgBox(Dts.Connections(0).ConnectionString)

cn.ConnectionString = "" + Dts.Connections(0).ConnectionString

cn.Open()

MsgBox(Err.Description)

command.Connection = cn

command.CommandType = CommandType.Text

command.CommandText = "insert into pay_dur(code) values('1')"

command.ExecuteNonQuery()

command = Nothing

cn.Close()

End Sub

好了,到此结束了,如果你知道第一种解决方法或者还有其他解决方法,还请指点,非常感谢

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有