gpt4 book ai didi

sql-server - 连接断开时干净地关闭 SQL 连接

转载 作者:行者123 更新时间:2023-12-02 03:22:58 25 4
gpt4 key购买 nike

只是想知道是否有一种方法可以在 VB.NET 中(也可以在 C#.NET 中)丢失连接时以最干净的方式关闭所有 SQL 连接和命令。

我要实现的目标:

使用 System.Net.NetworkInformation.NetworkAvailabilityChanged 事件,我正在监视连接是否已丢失。如果它丢失了,我将禁用所有用户输入 - 效果很好。网络重新打开,UI 已启用。 (竖起大拇指)

然而,现在我的困境来了。如果在连接断开之前执行 SQL 查询然后网络丢失,则查询会按预期返回空值,但是如果那是数据表/字段的中间填充,那么我会得到 NullReferenceExceptions。

我的问题是:

连接断开后,是否有办法干净地退出子组件?我已经尝试过 Application.ExitThread,但这似乎并没有完全解决它。我是否需要将已删除的连接处理程序放入我的对象中,以便在删除连接时相应的对象不会返回或尝试分配空数据?

非常感谢任何帮助。不要求纯代码,如果可能的话需要解释。干杯。

最佳答案

如果您遵循“使用”最佳实践,例如:

Using cn As New SqlConnection(connectionString)
...
End Using

然后编译器将生成在抛出异常时清理连接的代码。

关于sql-server - 连接断开时干净地关闭 SQL 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32003660/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com