【发布时间】:2011-08-16 19:36:48
【问题描述】:
我在 ADO.Net 应用程序中与 SQL Server 的 ADO-DB 连接存在问题。 我在 Web 服务启动时打开连接,并在结束时关闭它。这意味着只要服务运行,连接就会打开。 我将连接传递给实际处理事务的 COM dll。 我现在面临一个问题,该命令执行一段时间后抛出异常,尽管之前相同的执行工作。但连接状态仅显示打开。 所以我们必须关闭连接并打开它并重试事务。这样它就可以工作了。 但我想知道根本原因,这是一个实际的解决方案。 还有一件事,我们现在只有一个客户。
【问题讨论】:
-
你有什么例外?服务启动时打开连接是什么意思?您的意思是每个请求打开连接还是在应用程序的整个生命周期中只打开一次? COM 组件对连接有什么作用?改进您的问题,因为您错过了非常重要的细节。
-
来自 C++(COM dll) 的异常只是 E_FAIL。当我在 .Net 中测试相同的东西时,异常是“连接失败”。当我的 web 服务启动时,我正在打开连接。(仅适用于应用程序的整个生命周期)。COM 组件是实际执行所有事务的组件。连接对象被传递给 COM 组件。
标签: .net web-services interop com-interop adodb