views:

1206

answers:

1

My client is using Access as a front end to a SQL Server database. They recently started getting ODBC - 3146 errors from time to time when running some reports. From what I can tell, this is just a generic ODBC call failed error.

I've tried sticking some error handling in the VB script that is launching the reports, but I am not having any luck getting extra error information.

Code looks a bit like this.

Public Function RunReports()
  On Error GoTo MyErrorTrap

  DoCmd.OpenReport "blah", acViewPreview
  DoCmd.Close

  DoCmd.OpenReport "foo", acViewPreview
  DoCmd.Close

Exit_function:
  Exit Function

MyErrorTrap:
  Dim errX As DAO.Error
  Dim MyError As Error
  If Errors.Count > 1   'This always seems to be 0, so no help
    For Each errX In DAO.Errors  'These are empty even if dont check for Errors.Count
      Debug.Print "ODBC Error"
      Debug.Print errX.Number
      Debug.Print errX.Description
    Next errX
  Else
    Debug.Print "VBA Error"
    Debug.Print Err.Number
    Debug.Print Err.Description
  End If

  'Also have tried checking DBEngine.Errors, but this is empty too

End Function

I've also enabled tracing on the ODBC side, but that has bogged things down way too much, and I am so far unable to recreate the ODBC error.

I am completely open for suggestions on how to diagnose this.

+1  A: 

Can you put in the error handling in the report itself? Unless the report could not open or close, I wouldn't expect an error here.

Jeff O
I'm not an Access guy, any suggestions on where/how to put the error trapping in a report? Assuming there is a way to put the trapping on a single report, anyway to register some sort of global handler (they have several reports, and the problem doesn't happen in the same one).
Aaron Hinni
Er, what about the reports OnError event?
David-W-Fenton
I hooked into the OnError event, but still couldn't get anything better than the "call failed" error. My guess is that they were running into a timeout error, and I was able to speed things up with a table index, and a WHERE clause in the common query they were using for the reports.
Aaron Hinni