4个回答
展开全部
一般在重要、且容易出错的数据操作代码中加入错误捕捉模块,如on error或者try catth等错误处理模块来处理这个错误。
例如,VB.NET 连接数据库,使用try来捕捉错误,并处理错误的典型情况如下:
Try
Dim tmpcon As New SqlClient.SqlConnection(“数据库连接字符串”)
tmpcon.Open()
Catch ex As Exception
MsgBox("数据库连接出错")
...错误善后处理的代码
End Try
例如,VB.NET 连接数据库,使用try来捕捉错误,并处理错误的典型情况如下:
Try
Dim tmpcon As New SqlClient.SqlConnection(“数据库连接字符串”)
tmpcon.Open()
Catch ex As Exception
MsgBox("数据库连接出错")
...错误善后处理的代码
End Try
更多追问追答
追问
ConnStr = "Provider=SQLNCLI10.1;Data Source=js220049;User ID=sa;Password=sa;Initial Catalog=衡阳北站"
Conn.Open ConnStr
rs.CursorLocation = adUseClient
rs.Open Trim$(sql), Conn, adOpenDynamic, adLockOptimistic
Set Selectsql = rs
问题在“Conn.Open ConnStr”句
追答
ON ERROR GOTO ERR_EXT
ConnStr = "Provider=SQLNCLI10.1;Data Source=js220049;User ID=sa;Password=sa;Initial Catalog=衡阳北站"
Conn.Open ConnStr
rs.CursorLocation = adUseClient
rs.Open Trim$(sql), Conn, adOpenDynamic, adLockOptimistic
Set Selectsql = rs
GOTO THIS_END
:ERR_EXT
MSGBOX "出现错误"
错误处理代码
:THIS_END
结束代码
简要说明:
ON\ ERROR GOTO 语句指定当发生错误时,跳转到指定节点:ERR_EXT
当有错误时,ERR_EXT 处理完错误后,直接运行到:THIS_END节点。
当代码运行正确时候,在最末尾处直接GOTO跳转到THIS_END节点。
数据库的连接逻辑错误是无法提前获取的(除非是你的代码语法错误或者一些可预见性的错误情况),如数据库连接的外部环境因素:网络故障,数据库临时故障,软件环境临时故障,超出最大连接数,超出内存等等,这些都是不确定因素,也是不可预知的因素。
如果需要提前预测,一般的做法也是编写一个自定义模块,在正式连接操作数据库之前,临时调用模块去尝试打开一下指定数据库,如果顺利打开,返回True,则说明当前数据库能连接,如果不能打开,则返回False,表示当前数据库无法正常连接。
展开全部
这种错误应该不能用on error 来扑捉吧?代码放上来看看。单步调试看看哪句代码有问题。把关键代码贴上来。
更多追问追答
追问
ConnStr = "Provider=SQLNCLI10.1;Data Source=js220049;User ID=sa;Password=sa;Initial Catalog=衡阳北站"
Conn.Open ConnStr
rs.CursorLocation = adUseClient
rs.Open Trim$(sql), Conn, adOpenDynamic, adLockOptimistic
Set Selectsql = rs
问题在“Conn.Open ConnStr”句
追答
额,你应该补充问题不是追问,因为我也不太懂连SQL。话说 Data Source=js220049这句不需要路径吗? 你也可以看看用On Error Resume Next放前面看看能不能运行过去,能过去就说明能捕获错误,然后看看错误信息。 Debug.Print Err.Description
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
同一楼,
来自:求助得到的回答
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询