Monday, 1 October 2012

ActiveX Data Objects (ADO)


ADO is another data access method. ADO data model has a collection of objects using which you can access and manipulate any database that is based on OLEDB interface (more about it later). ADO model is simple. It has fewest objects in its object model.  ADO is the data model for databases that are accessed using OLEDB interface, where as RDO is the data model for databases that are accessed using ODBC interface.

What is OLEDB (OLE Database)?
OLEDB is an entirely new method to connect to databases.  OLEDB is replacing ODBC. OLEDB provides flexibility and ease of use than ODBC. OLEDB was designed to allow access to data of various formats. That means the data need not be in the form of a relation database and accessed using SQL. 

OLEDB needs a provider, which is a program that can sit between the application and the database (something like an ODBC driver). So when you want to access a database using OLEDB interface, you have to make sure that you have OLEDB provider for that database. Microsoft has provided the following OLEDB providers.

¨       Microsoft OLE DB provider for ODBC drivers
¨       Microsoft Jet 3.51 OLEDB provider
¨       Microsoft OLE DB provider for Oracle
¨       Microsoft OLE DB provider for SQL Server
¨       Microsoft OLE DB provider for Directory Services

Note: You can access any ODBC data source through OLEDB using OLE DB provider for ODBC drivers, if no OLEDB provider is available.


Figure 19.1: OLEDB interface.

ActiveX Data Object Model
This is a collection of objects that is used to access the database using OLEDB as the underlying interface. ADOs are simple compared with DAO and RDO.

ActiveX Data Objects allow you to access only data and not the schema (table definitions, column definitions etc).  As the result it has very few objects in it object model.
The following are the objects in ActiveX data object model.

Object
What it does?
Connection
Allows you to connect to the database.
Command
Is used to execute commands that are supported by the database.
RecordSet
Contains the collection of records retrieved by executing a query.
Table 19.1: Important objects in ADO data model.

There are some more objects in the object model of ADO. But the three objects mentioned above are the most important objects.

Let us discuss about each of these objects.

Connection Object
Connection object allows the application to connect to the database.  It represents an open connection to the data source.

To establish a connection with a particular database, you have to set the ConnectionString property to the required string, which specifies the OLEDB provider to be used and the data source to be accessed.

To connect to Products.Mdb, enter:

Dim con As ADODB.Connection

 Set con = New ADODB.Connection
 
 con.ConnectionString = "PROVIDER=Microsoft.jet.OLEDB.3.51; _
                   DATA SOURCE=D:\srikanth\products.mdb"
 con.Open   ‘ open the connection

 ‘ Or you can also supply connectionstring at the time of opening the
 ' connection

 con.Open "PROVIDER=Microsoft.jet.OLEDB.3.51; _
              DATA SOURCE= D:\srikanth\products.mdb"

The following are the important collections, methods, and properties of the Connection object

Type
Name
Meaning
Collections
Errors
Contains error objects related to a single failure.

Properties
Contains all the properties specific to collection.
Method
BeginTrans, CommitTrans, Rollbacktrans
Are used to start a new transaction and either to commit or rollback the transaction.

Open
Open a new connection to the data source.

Execute
Execute the given command. If command is a query, it returns a recordset object.

Openschema
Returns information about the data source.
Property
Connectionstring
Contains information that is used to connect to data source.

Provider
Indicates the name of the provider.

Mode
Indicates the available permissions for modifying data in a connection.

State
Indicates whether connection object is opened or closed.

Cursorlocation
Indicates the cursor location of the cursor engine. For more details, see “Cursor Location property”.

DefaultDatabase
Indicates the default database for the connection object.
Table 19.2: Members of Connection object.

CursorLocation Property
Determines the location where cursor is managed.  The following are the valid settings.

Constant
Description
AdUseNone
No cursor services are used. (This constant is obsolete and appears solely for the sake of backward compatibility.)
AdUseClient
Uses client-side cursors supplied by a local cursor library. Local cursor engines will often allow many features that driver-supplied cursors may not, so using this setting may provide an advantage with respect to features that will be enabled. For backward compatibility, the synonym adUseClientBatch is also supported.
AdUseServer
Default. Uses data-provider– or driver-supplied cursors. These cursors are sometimes very flexible and allow for additional sensitivity to changes other user make to the data source.
Table 19.3: Setting for CursorLocation property.


Command Object
A Command object is a definition of a specific command that you intend to execute against a data source. The following are important collections, methods and properties.

Type
Name
Meaning
Collection
Parameters
Contains all the parameters of the command object.

Properties
Contains properties that are specific to command object.
Method
CreateParameter
Creates a new parameter with the specified properties. For more information, see “Parameter Object”.

Execute
Executes the given command.

Cancel
Cancels the execution of an asynchronous command.
Property
ActiveConnection
Specifies to which connect the command object should belong.

CommandText
Contains the command that you want to execute.

Commandtype
Indicates the type of command. Depending upon this the CommandText is interpreted.

Prepared
If set to true, the compiled version of the command is saved before first execution of the command. This improves performance from second execution onwards.
Table 19.4: Members of Command object.

The following example uses a command object to execute an Update command:

Private Sub Command1_Click()
    Dim con As New ADODB.Connection
    Dim com As New ADODB.Command
    Dim p1 As ADODB.Parameter
    Dim p2 As ADODB.Parameter
   Dim ref As Long
   con.Open "PROVIDER=Microsoft.jet.OLEDB.3.51;DATA SOURCE=D:\vb60\biblio.mdb"
   Set com.ActiveConnection = con
   com.CommandType = adCmdText
   com.CommandText = "Update Authors set [year born]=? where au_id=?"
   Set p1 = com.CreateParameter("yb", adInteger, adParamInput, , txtyb.Text)
   Set p2 = com.CreateParameter("auid", adInteger, adParamInput, , txtauid.Text)
   com.Parameters.Append p1
   com.Parameters.Append p2
   'Execute the command
  
   com.Execute ref
  
   If ref = 0 Then
     MsgBox "Updation is not successful"
   Else
     MsgBox "Updation is successful"
   End If

End Sub
Listing 19.2: Sample code using Update command.

Recordset object
A Recordset object represents a set of records taken from the given base table or retrieved from the database using the given query. Though Recordset contains a collection of records, only one record can be accessed at a time, which is called as the current record. However, you can move next and move previous to access all the records in the Recordset.

The following are the important collections, methods, and properties of Recordset object.

Type
Name
Meaning
Collection
Fields
Contains the details of all the fields in the Recordset.

Properties
Contains the properties that are specific to Recordset object.
Methods
Addnew
Adds a new blank record at the end of recordset.

CancelBatch
Cancels a pending batch update.

CancelUpdate
Cancels a pending update. But it should be called before Update method is invoked.

Clone
Creates a duplicate recordset from an existing recordset.

GetRows
Returns the data from the given number of rows and given fields starting at the specified record (otherwise current record). The return value is to be copied into a double dimension array.

NextRecordset
Returns the next recordset when used with compound command statement, where you can give multiple select commands and execute them one after another.

Requery
Updates the data in the Recordset by executing the query on which Recordset is based.

Resync
Refreshes either current record or the specified record with Filter property or all records with the underlying records.

Supports
Returns true if the specified functionality is supported by Recordset. For the list of features, please see on-line documentation.

Close
Closes recordset and releases memory associated with recordset.

Delete
Deletes current record in the recordset.

Move, MoveFirst,
MoveNext, MovePrevious
and MoveLast
Used to move record pointer within the recordset.

Update
Makes the changes made to recordset permanent.

UpdateBatch
Writes all pending batch updates to disk.
Properties
AbsolutePage
Contains the absolute page number of the page in which current record is.

AbsolutePosition
Returns the ordinal position of the current record in the recordset.

ActiveConnection
Contains the connection object to which recordset belongs.

PageCount
Returns how many pages of records are there in recordset.

PageSize
Specifies how many records constitute one page. Default is 10.

RecordCount
Contains the number of records the recordset object currently has.

MaxRecords
Indicates the maximum number of records to be sent to recordset from query.

Status
Indicates the status of the current record with respect to batch updates or other bulk operations.

State
Returns the current state of the recordset object – whether opened or closed and so on.

Cachesize
Indicates the number of records from the Recordset object that are cached locally.

CursorLocation
Indicates the location where cursor is managed.

CursorType
Determines the type of cursor to be used to manage records of the recordset.

LockType
Specifies the type of lock that is to be applied on records during editing.

EditMode
Returns the editing status of the current record. See EditMode below.

MarshalOptions
Specifies whether all records are marshaled or only modified records are marshaled.

Filter
Allows you to specify which records are to be filtered based on either the given condition  or array of bookmarks or the specified options, such as specifying only effected records are to be displayed.

BOF, EOF
Return true when the record pointer reaches either beginning of the file or end of the recordset.

Source
Contains the source from where records were taken into Recordset.

Bookmark
Returns the bookmark of the current record or changes the current record to the one whose bookmark is set to this.
Table 19.5:  Collections, Methods and Properties of Recordset object.

EditMode property

Returns the editing status of the current record in the recordset. The mode may be any of the following.


Option
Meaning
AdEditNone    
Indicates no editing operation is in progress.
AdEditInProgress           
Indicates that the current record is being edited. That means it has been modified but not yet saved.
AdEditAdd                 
Indicates that AddNew method has been invoked and new record is not yet saved.

Let us write a snippet that displays the details of all authors using Recordset object.

Private Sub Command2_Click()
   Dim con As New adodb.Connection
   Dim rs As adodb.Recordset
     
   con.Open "PROVIDER=Microsoft.jet.OLEDB.3.51;DATA SOURCE=D:\vb60\biblio.mdb"
    
   'Execute query and get records into recordset
  
   Set rs = con.Execute("select * from authors where au_id < 10")
  
   Do Until rs.EOF
      Print rs("au_id"), rs("author")
      rs.MoveNext
   Loop
   rs.Close
   Set rs = Nothing
   con.Close
   Set con = Nothing
End Sub
Listing 19.3: Using RecordSet object to display details of Authors.

That is all about three major objects – connection, command and Recordset – of ActiveX Data Objects. We will see more usage of ADOs later in this chapter.

Using ActiveX Data Control
We have used data control, which is a control in standard set of controls. Now we will use an ActiveX control called as ActiveX Data Control, which uses ADOs to access a database for which we have an OLEDB provider.

Here are the steps to display the details of publishers taken from biblio.mdb.

1.      Start a new project using File->New Project and select Standard Exe as the type of the project.
2.      Load Microsoft ADO Data Control 6.0 (OLEDB) into project using Project->Components option and check the above mentioned ActiveX control.
3.      Place ADODC (ActiveX data objects data control) on the form.
4.      Select ADODC properties options from popup menu of the ADODC control.
5.      This brings up property pages of ADODC.
6.      Click on Build button in Use Connection String  radio button.
7.      ADODC displays Data Link Properties windows.
8.      Make sure Provider tab is selected and select Microsoft jet 3.51 OLEDB  Provider (figure19.3)
9.      Then click on Connection tab (figure 19.4)
10.  Click on three dots and select the name of data file that you want to access.
11.  At this stage you can test your connection to the database by clicking on Test Connection button.
12.  Advanced tab mainly deals with access permissions, and All tabs displays the entire information.
13.  Click on Ok in Data Link Properties window to close it and come back to property pages of  activex data control.
14.  At this stage you should see connect string created by Visual Basic placed in Use connection String option button.
15.  Now select RecordSource tab and adCmdTable from the type of the command dropdown list box.
16.  Click on down arrow for the next combo box and  from the list of valid tables select Authors tables (shown in figure 19.5)
17.  Click on Ok to close property pages.
18.  Place three textboxes on the form and corresponding labels. Change the properties of these controls as follows.

Control
Property
Value
Text1
Datasource
Adodc1

Datafield
Au_id

Name
txtauid
Text2
Datasource
Adodc1

Datafield
Author

Name
txtauthor
Text3
Datasource
Adodc1

Datafield
Year born

Name
Txtyb

19.  Change remaining properties as required.
20.  Run the project to get the details of authors into three textboxes.
Note: This application is same as the application we developed in “Accessing Data using Data Control” section of chapter 15. But instead of using data control, we have used an ADODC to access the data. And there the underlying objects are Data access object and here the objects are ActiveX Data Objects.

ActiveX Data Control does the same job as the standard Data Control but in a different way. The fundamental difference is; standard data control is based on ADO and ADODC is based on ADO & OLEDB.  And there are different set of events and properties for ADODC.
 
Figure 19.2: General Property Page of ADODC.
 

Figure 19.3: List of Providers.

Properties of ADODC
The following are properties that are specific to ADODC.

Property
Meaning
BOFAction
Specifies the action to be taken when record pointer reaches beginning of the underlying Recordset.
CacheSize
Specifies the number of records to be kept in the memory.
Caption
The message to be displayed on the control.
Commandtimeout
Specifies the amount of time to wait for the command to return. Time is specified in seconds. Default is 30.
Commandtype
Specifies the type of command. Valid options are, adcmdUnKnown, adCmdText, adCmdTable, and adCmdStoredProc.
ConnectionString
Contains the information required to connect to the database.
ConnectionTimeout
The number of seconds to wait before aborting connection. This is specified in seconds. Default is 15.
CursorLocation
Sepecifies whether client-side or server-side cursors are used.  Default is adUseClient – client side cursor.
CursorType
Specifies which type of cursor is to be used. Default is adOpenStatic.
EOFAction
Indicates the action to be taken when record pointer reaches end of the recordset.
LockType
Specifies the type of lock to be used. The default is adLockOptimistic.
Maxrecords
Specifies the number of records retrieved at the time of opening the underlying recordset.
Mode
Specifies in which mode the recordset is to be opened. The mode of recordset determines what operations other users can perform on the Recordset.
Orientation
Whether to display recordset vertically or horizontally.
Password
Password of the user currently connected.
RecordSource
The name of the table or stored procedure or SELECT command that supplies data.
Username
Name of the user currently connected.

Table 19.6: Properties of ADODC.

 


Figure  19.4: Connection attributes.

Figure 19.5: Record Source attributes.


The following is an example where the ADODC’s data source is changed and underlying recordset is recreated.

With Adodc1
    .CommandType = adCmdText
    .LockType = adLockReadOnly
    .CursorType = adOpenStatic
    .RecordSource = "select * from authors where au_id < " &  txtau_id.Text
    .Mode = adModeReadWrite
    .Refresh  ' recreate recordset
End With

Note: Refresh method of ADODC is used to reopen the database and recreate the underlying Recordset. The other method available for ADODC is UpdateControl, which refreshes the data of bound control with the data of current record.

Events of ADODC
The events of ADODC can be divided into two main groups. One group contains events that occur before the operation is performed (WillMove) and another group contains events, which occur after the operation is completed (MoveComplete).

Will events which will occur before the action takes place and gives you an opportunity to cancel the operation that is about to take place using cancel parameter. See the example later.

The following are the events that are specific to ADODC.

Event
When it occurs?
Fetchprogress
Periodically during a lengthy fetch operation.
FetchComplete
After all records of the recordset are fetched.
WillMove
Before record pointer moves from one record to another record.
Movecomplete
After record pointer has moved from one row to another.
EndOfRecordset
When record pointer has moved past the last record.
WillchangeRecordset
Before a change is made to recordset.
RecordsetChangeComplete
After change is made to recordset.
WillchangeRecord
Before the changes of the current record are sent to database.
RecordChangeComplete
After the record in the data source is modified with the data in the recordset.
WillChangeField
Before the current fields in the recordset is updated.
FieldChangeComplete
After the current field is updated.
Table 19.7: Events of ADODC.

To cancel user moving to last record:

Private Sub Adodc1_WillMove(ByVal adReason As ADODB.EventReasonEnum, adStatus As ADODB.EventStatusEnum, ByVal pRecordset As ADODB.Recordset)
‘ if user is moving to last record
 If adReason = adRsnMoveLast Then
       adStatus = adStatusCancel    ‘ cancel the operation
 End If
End Sub
Listing 19.3:Code to prevent moving to last record.

No comments:

Post a Comment