How to check if an oledbcommand succeeded?
Im working on an access database, and I want to know how can I fix the code below so that I could display the correct information to the user. The problem is, I want to display an error message if the oledbcommand did not succeed.
        Try
        cn = New OleDbConnection(" Provider=Microsoft.Jet.OLEDB.4.0;Data Source=F:\ro.mdb")
        'provider to be used when working with access database
        cn.Open()
        cmd = New OleDbCommand("select * from [Table1]", cn)
        cmd.CommandText = "insert into [Table1]([LNAME], [FNAME], [MNAME], [POS], [UNAME], [PASS]) values('" + lstname + "','" + frsname + "','" + midname + "','" + post + "','" + usrname + "','" + pword + "')"
        cmd.ExecuteNonQuery()
    Catch
        MsgBox("Either one of the text box is empty or the IDNUMBER开发者_运维技巧 entered is already on the database", MsgBoxStyle.Critical)
    End Try
This started as a SqlException and was changed to Oledb for this question. Sorry for not testing.
 Try    
      ... 
    Catch dbException as OledbException
         Dim myErrors as OledbErrorCollection = dbException.Errors
         Dim i as Integer
           For i = 0 to myErrors.Count - 1
               MessageBox.Show("Index #" & i & ControlChars.Cr & _
                   "Error: " & myErrors(i).ToString() & ControlChars.Cr)
           Next i 
    Finially
       ...
Figure out what exceptions you'd like to trap and catch them explicitly
Try
Catch se As SpecialException
  MsgBox("Error1")
Catch e As Exception    ' Catch all other exceptions.
  MsgBox("General Error")
End Try
 
         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论