ADO 2.7 Samples

Execute, Requery, and Clear Methods Example (VB)

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 ExecuteX()

    ' 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=MyServer;Initial Catalog=Pubs;User Id=sa;Password=; "
   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

   ' Clear extraneous errors from the Errors collection
   Cnxn.Errors.Clear

   ' 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
   On Error GoTo Err_Execute
   Cnxn.Execute strSQLRestore, , adExecuteNoRecords
   On Error GoTo 0

   ' 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

   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
   Resume Next

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

See Also

Clear Method | Command Object | Connection Object | Error Object | Execute Method (ADO Command) | Execute Method (ADO Connection) | Recordset Object | Requery Method

© 1998-2001 Microsoft Corporation. All rights reserved.