David M. Kroenke’s
Database Processing:
Fundamentals, Design, and Implementation
Chapter Twelve:
ODBC, OLE DB, ADO,
and ASP
Part Two
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-1
OLE DB
• OLE DB is an implementation of the Microsoft
OLE object standard.
– OLE DB objects are COM objects and support all required
interfaces for such objects.
• OLE DB breaks the features and functions of a DBMS
into COM objects, making it easier for vendors to
implement portions of functionality.
– This characteristic overcomes a major disadvantage of ODBC.
– With ODBC, a vendor must create an ODBC driver for almost all
DBMS features and functions in order to participate in ODBC at
all.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-2
Object-Oriented Concepts
• An object-oriented programming object is an
abstraction that is defined by its properties and
methods.
– An abstraction is a generalization of something.
– A property specifies set of characteristics of an
object.
– A method refers to actions that an object can
perform.
– A collection is an object that contains a group of
other objects.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-3
OLE DB Goals
• Create object interfaces for DBMS functionality pieces:
– Query, update, transaction management, etc.
• Increase flexibility:
–
–
–
–
Allow data consumers to use only the objects they need.
Allow data providers to expose pieces of DBMS functionality.
Providers can deliver functionality in multiple interfaces.
Interfaces are standardized and extensible.
• Provide object interfaces over any type of data:
– Relational and non-relational database, ODBC or native, VSAM
and other files, Email, etc.
• Do not force data to be converted or moved from where
it is.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-4
OLE DB Basic Constructs
• There are data consumers and data providers:
– Data consumers - Users of OLE DB functionality.
– Data providers - Sources of OLE DB functionality.
• An interface is a set of objects and the properties and
methods they expose in that interface:
– Objects may expose different properties and methods in different
interfaces.
• An implementation is how an object accomplishes its
tasks:
– Implementations are hidden from the outside world and may be
changed without impacting the users of the objects.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-5
OLE DB Terminology:
Data Providers
• A rowset is equivalent to a cursor.
• OLE DB has two types of data providers:
– Tabular data provider — exposes data via rowsets.
• Examples: DBMS, spreadsheets, ISAMs, email.
– Service provider — a transformer of data through
OLE DB interfaces.
• It is both a consumer and a provider of transformed data.
• Examples: query processors, XML document creator.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-6
Rowset Interfaces
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-7
Active Data Objects (ADO)
• Active Data Objects (ADO) characteristics:
– A simple object model for OLE DB data consumers
– It can be used from VBScript, JScript, Visual Basic,
Java, C#, C++
– It is a single Microsoft data access standard
– Data access objects are the same for all types of OLE
DB data
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-8
Invoking ADO from Active Server Pages
• In Microsoft’s Active Server Pages (ASP)
are Web pages where:
– Statements are enclosed within the
characters <% . . .%>.
– ASP statements are processed on the Web
server.
– Other (HTML) statements are processed by
the client Web browser.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-9
The ADO Object Model
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-10
Connection Object
• A connection object establishes a connection
to a data provider and data source.
– Connections have an isolation mode.
• Once a connection is created, it can be used to
create RecordSet and Command objects.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-11
RecordSet Objects
• RecordSet objects represent cursors:
– They have both CursorType and LockType properties.
– RecordSets can be created with SQL statements.
– The Fields collection of a RecordSet can be
processed to individually manipulate fields.
– The Errors collection contains one or more error
messages that result from an ADO operation.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-12
Command Object
• The command object is used to execute
stored parameterized queries or stored
procedures:
– Input data can be sent to the correct ASP
using the HTML FORM tag.
– Table updates are made using the RecordSet
Update method.
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-13
ADO Constants:
Isolation Levels
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-14
ADO Constants:
Cursor Levels
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-15
ADO Constants:
Lock Types
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-16
Connection Object:
ASP Code
<%
Dim objConn
Set objConn = Server.CreateObject (“ADODB.connection”)
objConn.IsolationLevel = adXactReadCommitted
‘ use ADOVBS
objConn.Open “ViewRidgeSS”,
%>
<!--#include virtual =“ADOExamples/ADOVBS.inc -->
<%
objConn.Open “DSN=ViewRidgeOracle2;UID=DK1;PWD=Sesame”
%>
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-17
RecordSet Object:
ASP Code
<%
Dim objRecordSet, varSql
varSQL = “SELECT * FROM ARTIST”
Set objRecordSet = Server.CreateObject(“ADODB.Recordset”)
objRecordSet.CursorTye = adOpenStatic
objRecordSet.LockType = adLockReadOnly
objRecordSet.Open varSQL, objConn
%>
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-18
Fields Collection:
ASP Code
<%
Dim varI, varNumCols, objField
varNumCols = objRecordSet.Fields.Count
For varI = 0 to varNumCols - 1
Set objField = objRecordSet.Fields(varI)
‘ objField.Name now has the name of the field
‘ objField.Value now has the value of the field
‘ can do something with them here
Next
>%
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-19
Errors Collection:
ASP Code
<%
Dim varI, varErrorCount, objError
On Error Resume Next
varErrorCount = objConn.Errors.Count
If varErrorCount > 0 Then
For varI = 0 to varErrorCount - 1
Set objError = objConn.Errors(varI)
‘ objError.Description contains
‘ a description of the error
Next
End If
>%
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-20
Command Object:
ASP Code
<%
Dim
objCommand, objParam, objRs
‘Create the Command object, connect it to objConn and
set its format
Set objCommand = Server.CreateObject(“ADODB.command”)
Set objCommand.ActiveConnection = objConn
objCommand.CommandText=“{call FindArtist (?)}”
‘Set up the parameter with the necessary value
Set objParam = objCommand.CreateParameter (“Nationality”,
adChar, adParamInput, 25)
objCommand.Parameters.Append objParam
objParam.Value = “Spanish”
‘Fire the Stored Proc
Set objRs = objCommand.Execute
>%
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-21
ADO
Example:
Reading a
Table
Artist.asp
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-22
ADO Example: Reading a Table
The Artist.asp Results
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-23
David M. Kroenke’s
Database Processing
Fundamentals, Design, and Implementation
(10th Edition)
End of Presentation:
Chapter Twelve Part Two
DAVID M. KROENKE’S DATABASE PROCESSING, 10th Edition
© 2006 Pearson Prentice Hall
12-24