怎样向老组件传递ADO连接对象?

Equn 2007-06-14 11:59:41
以前用VB6.0开发的组件,在C#中引用后老组件及ADO2.6,需要向老组件传递一个“ADODB.Connection”数据库连接对象,代码如下:

SqlServer=ConfigurationSettings.AppSettings.Get("SqlServer");
SqlDb=ConfigurationSettings.AppSettings.Get("SqlDb");
SqlDbUid=ConfigurationSettings.AppSettings.Get("SqlDbUid");
SqlDbPwd=ConfigurationSettings.AppSettings.Get("SqlDbPwd");


ADODB.Connection conn=new ADODB.Connection();
conn.Open("Provider=SQLOLEDB.1;Server="+SqlServer+";UID="+SqlDbUid+";PWD="+SqlDbPwd+";Database="+SqlDb,"","",0);
configs sys=new configs(); //configs为老的组件
sys.init(conn); //向老组件传递连接对象


错误提示:
E:\My Documents\Visual Studio Projects\AutoUpdate\AutoUpdate.cs(104): 与“EqunNews._configs.init(ref ADODB.Connection)”最匹配的重载方法具有一些无效参数
E:\My Documents\Visual Studio Projects\AutoUpdate\AutoUpdate.cs(104): 参数“1” : 无法从“ADODB.Connection”转换为“ref ADODB.Connection”



老组件使用的ADO对象版本为2.6,在C#中也引用了同一版本ADO。

.Net初学者请求帮助,谢谢!
...全文
190 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
Equn 2007-06-14
  • 打赏
  • 举报
回复
很麻烦吗? 分不够可以加。
北京的雾霾天 2007-06-14
  • 打赏
  • 举报
回复
改成这样的试试看:

sys.init(ref conn); //向老组件传递连接对象
onekey 2007-06-14
  • 打赏
  • 举报
回复
晕,组件写的有问题。
为什么不是传递进去一个字符串呢?
试试 sys.init(ref conn);
Equn 2007-06-14
  • 打赏
  • 举报
回复
up

111,092

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧