以文本方式查看主题 - Foxtable(狐表) (http://foxtable.com/bbs/index.asp) -- 专家坐堂 (http://foxtable.com/bbs/list.asp?boardid=2) ---- 关于Connections.TryConnect这个问题! (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=179911) |
-- 作者:benben325 -- 发布时间:2022/9/17 10:01:00 -- 关于Connections.TryConnect这个问题! 一旦数据源连不上,这个检测连接要花好久,一直处于卡死状态。。。其实一般3秒都没连上 基本上就连不上了,有什么方法可以快速判断连接状态? 或者3秒没连上 我直接判断为连接失败! |
-- 作者:z769036165 -- 发布时间:2022/9/17 10:03:00 -- http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&Id=62475 参考这个吧
|
-- 作者:benben325 -- 发布时间:2022/9/17 10:37:00 -- 这个帖子我看过,我只需要判断数据源是否连接,因此引用了如下代码: Dim str As String = "Provider=SQLOLEDB.1;Password=" & r("密码") & ";Persist Security Info=True;User ID=" & r("用户名") & ";Initial Catalog=master;Data Source=" & r("服务器") Dim mess As String = "数据源连接成功!" Try Dim conn As ADODB.Connection conn = New ADODB.Connection conn.ConnectionString = str conn.Open conn.close Catch ex As Exception mess = "SQL数据库" & Err.Description End Try MessageBox.Show(mess) 可是这部分代码发现时间仍然需要很久! |
-- 作者:有点蓝 -- 发布时间:2022/9/17 10:42:00 -- conn = New ADODB.Connection conn.ConnectionTimeout=3
|
-- 作者:benben325 -- 发布时间:2022/9/17 10:47:00 -- 老师,不行额。 Dim str As String = "Provider=SQLOLEDB.1;Password=" & r("密码") & ";Persist Security Info=True;User ID=" & r("用户名") & ";Initial Catalog=master;Data Source=" & r("服务器") Dim mess As String = "数据源连接成功!" Try Dim conn As ADODB.Connection conn = New ADODB.Connection conn.ConnectionTimeout=3 conn.ConnectionString = str conn.Open conn.close Catch ex As Exception mess = "SQL数据库" & Err.Description End Try MessageBox.Show(mess) 改成这样仍旧花了一分钟左右 |
-- 作者:有点蓝 -- 发布时间:2022/9/17 11:34:00 -- ip可以访问的情况下,ConnectionTimeout才有效。先判断IP是否可用,2楼的贴估计也没有怎么仔细看 If Network.Ping("192.192.192.192", 1) Then Dim str As String = "Password=888;Persist Security Info=True;User ID=sa;Initial Catalog=abc;Data Source=192.192.192.192;Connection Timeout=1" Dim mess As String = "数据源连接成功!" Try Dim conn As New system.Data.SqlClient.SqlConnection conn.ConnectionString = str conn.Open conn.close Catch ex As Exception mess = "SQL数据库" & Err.Description End Try MessageBox.Show(mess) Else Messagebox.Show("该服务器不可用") End If |