This example demonstrates the Execute method when run from both a Command object and a Connection object. It also uses the Requery method to retrieve current data in a Recordset, and the Clear method to clear the contents of the Errors collection. (The Errors collection is accessed via the Connection object of the ActiveConnection property of the Recordset.) The ExecuteCommand and PrintOutput procedures are required for this procedure to run.
'BeginExecuteVB 'To integrate this code 'replace the data source and initial catalog values 'in the connection string Public Sub Main() On Error GoTo Err_Execute ' connection, command, and recordset variables Dim Cnxn As ADODB.Connection Dim cmdChange As ADODB.Command Dim rstTitles As ADODB.Recordset Dim Err As ADODB.Error Dim strSQLChange As String Dim strSQLRestore As String Dim strSQLTitles Dim strCnxn As String ' Define two SQL statements to execute as command text strSQLChange = "UPDATE Titles SET Type = 'self_help' WHERE Type = 'psychology'" strSQLRestore = "UPDATE Titles SET Type = 'psychology' WHERE Type = 'self_help'" ' Open connection strCnxn = "Provider='sqloledb';Data Source='MySqlServer';" & _ "Initial Catalog='Pubs';Integrated Security='SSPI';" Set Cnxn = New ADODB.Connection Cnxn.Open strCnxn ' Create command object Set cmdChange = New ADODB.Command Set cmdChange.ActiveConnection = Cnxn cmdChange.CommandText = strSQLChange ' Open titles table Set rstTitles = New ADODB.Recordset strSQLTitles = "titles" rstTitles.Open strSQLTitles, Cnxn, , , adCmdTable ' Print report of original data Debug.Print _ "Data in Titles table before executing the query" PrintOutput rstTitles ' Call the ExecuteCommand subroutine below to execute cmdChange command ExecuteCommand cmdChange, rstTitles ' Print report of new data Debug.Print _ "Data in Titles table after executing the query" PrintOutput rstTitles ' Use the Connection object's execute method to ' execute SQL statement to restore data and trap for ' errors, checking the Errors collection if necessary Cnxn.Execute strSQLRestore, , adExecuteNoRecords ' Retrieve the current data by requerying the recordset rstTitles.Requery ' Print report of restored data using sub from below Debug.Print "Data after executing the query to restore the original information " PrintOutput rstTitles ' clean up rstTitles.Close Cnxn.Close Set rstTitles = Nothing Set Cnxn = Nothing Exit Sub Err_Execute: ' Notify user of any errors that result from ' executing the query If rstTitles.ActiveConnection.Errors.Count >= 0 Then For Each Err In rstTitles.ActiveConnection.Errors MsgBox "Error number: " & Err.Number & vbCr & _ Err.Description Next Err End If ' clean up If Not rstTitles Is Nothing Then If rstTitles.State = adStateOpen Then rstTitles.Close End If Set rstTitles = Nothing If Not Cnxn Is Nothing Then If Cnxn.State = adStateOpen Then Cnxn.Close End If Set Cnxn = Nothing If Err <> 0 Then MsgBox Err.Source & "-->" & Err.Description, , "Error" End If End Sub Public Sub ExecuteCommand(cmdTemp As ADODB.Command, rstTemp As ADODB.Recordset) Dim Err As Error ' Run the specified Command object and trap for ' errors, checking the Errors collection On Error GoTo Err_Execute cmdTemp.Execute On Error GoTo 0 ' Retrieve the current data by requerying the recordset rstTemp.Requery Exit Sub Err_Execute: ' Notify user of any errors that result from ' executing the query If rstTemp.ActiveConnection.Errors.Count > 0 Then For Each Err In rstTemp.ActiveConnection.Errors MsgBox "Error number: " & Err.Number & vbCr & _ Err.Description Next Err End If Resume Next End Sub Public Sub PrintOutput(rstTemp As ADODB.Recordset) ' Enumerate Recordset Do While Not rstTemp.EOF Debug.Print " " & rstTemp!Title & _ ", " & rstTemp!Type rstTemp.MoveNext Loop End Sub 'EndExecuteVB
Clear Method | Command Object | Connection Object | Error Object | Execute Method (ADO Command) | Execute Method (ADO Connection) | Recordset Object | Requery Method