Misplaced Pages

Microsoft Data Access Components: Difference between revisions

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 08:00, 13 July 2005 editTa bu shi da yu (talk | contribs)32,902 editsm History← Previous edit Latest revision as of 08:52, 30 May 2024 edit undoShhhnotsoloud (talk | contribs)Autopatrolled, Extended confirmed users, Page movers93,005 edits Fix ambiguous wikilink 
(516 intermediate revisions by more than 100 users not shown)
Line 1: Line 1:
{{Short description|Framework}}
'''MDAC''', or '''Microsoft Data Access Components''' is a ] architecture for providing access to information across an enterprise. It is made up of various components: ] (ADO), ] DB, and ] (ODBC). The current version is 2.8, but the product has had many different versions and many of its components have been depreciated and replaced by newer Microsoft technologies.
{{citation style|date=August 2013}}
{{Infobox software
| name = Microsoft Data Access Components
| screenshot = MDAC Architecture.svg
| caption = MDAC provides a uniform framework for accessing a variety of data sources on their ] platform
| developer = Microsoft
|latest_release_version = 2.8 SP1 (2.81.1117.6)
| latest_release_date = May 2005
| discontinued = yes
| operating system = ], ], ], ], ], ], ], ]
| genre = ]
| license = ]
| website = {{URL|http://msdn2.microsoft.com/en-us/data/aa937729.aspx}}
}}
'''Microsoft Data Access Components''' ('''MDAC'''; also known as '''Windows DAC''') is a ] of interrelated ] technologies that allows programmers a uniform and comprehensive way of developing applications that can access almost any data store. Its components include: ] (ADO), ], and ] (ODBC). There have been several deprecated components as well, such as the ], MSDASQL (the OLE DB provider for ODBC), and ] (RDS). Some components have also become ], such as the former ] ] and ].


The first version of MDAC was released in August 1996. At that time Microsoft stated MDAC was more a concept than a stand-alone program and had no widespread distribution method. Later Microsoft released upgrades to MDAC as web-based redistributable packages. Eventually, later versions were integrated with ] and ], and in MDAC 2.8 SP1 they ceased offering MDAC as a redistributable package.
==Current components==
;ADO
;ADOMD
;ADOX
;OLE DB
;SQLOLEDB
;Microsoft SQL Server Network Libraries
;ODBC
;SQLODBC


Throughout its history, MDAC has been the subject of several ], which led to attacks such as an ], although the vulnerabilities were generally fixed in later versions and fairly promptly. The current version is 2.8 ] 1, but the product has had many different versions and many of its components have been deprecated and replaced by newer Microsoft technologies. MDAC is now known as Windows DAC in ].
==Deprecated components==

;Jet
==Architecture==
;MSDASQL
The latest version of MDAC (2.8) consists of several interacting components, all of which are ] specific except for ] (which is available on several platforms). MDAC architecture may be viewed as three layers: a programming interface layer, consisting of ] and ], a database access layer developed by database vendors such as Oracle and Microsoft (], .NET managed providers and ] drivers), and the database itself. These component layers are all made available to applications through the MDAC ]. The ] Network Library, a proprietary access method specific to Microsoft SQL Server, is also included in the MDAC. Developers of Windows applications are encouraged to use ADO or ADO.NET for data access, the benefit being that users of the application program are not constrained in their choice of database architecture except that it should be supported by MDAC. Naturally, developers still have the choice of writing applications which directly access OLE DB and ODBC.
;Oracle ODBC

;RDS
===Microsoft SQL Server Network Library===
;JRO
The Microsoft SQL Server Network Library (also known as Net-Lib) is used by the Microsoft SQL Server to read and write data using many different ]s. Though Net-Lib is specific to the SQL Server, Microsoft includes it with MDAC. The SQL Server uses the Open Data Services (ODS) library to communicate with Net-Lib, which interfaces directly with the ] operating system line's ] ]. The SQL Server Network Library is controlled through the use of a Client Network Utility, which is bundled with the SQL Server.
;SQL XML

Each Net-Lib supported network protocol has a separate driver (not to be confused with a ]), and has support for a ] in its protocol stack. There are two general types of Net-Lib: the primary and the secondary. The primary Net-Lib consists of a ''Super Socket'' Net-Lib and the ''Shared Memory'' Net-Lib, while there are numerous secondary Net-Libs, including ] and ] network libraries (named pipes are a method of communicating with other processes via a system-persistent ] that is given an identity). The Microsoft OLE DB Provider for SQL Server (SQLOLEDB) communicates via primary Net-Libs.

The Super Socket Net-Lib deals with inter-computer communications and coordinates the secondary Net-Libs – though the TCP/IP secondary Net-Lib is an exception in that it calls on the ] API directly. The ], ], ], ], ], and ] Net-Libs were dropped from MDAC 2.5 onwards. The Network Library router had the job of managing all these protocols, however now only the named pipes secondary Net-Lib is managed by the router. The Super Socket Net-Lib also handles ] via the use of the Windows ] API.

The Shared Memory Net-Lib, on the other hand, manages connections between multiple instances of SQL Server that exist on one computer. It uses a ] area to communicate between the processes. This is inherently secure; there is no need for data encryption between instances of SQL Server that exist on one computer as the operating system does not allow any other process access to the instances' area of shared memory.

Net-Lib is also able to support the impersonation of a logged in user's security context for protocols that support authenticated connections (called ''trusted connections''). This allows Net-Lib to provide an integrated logon authentication mechanism via the use of ]. Windows Authentication is not supported on Windows 98 or Windows Me.<ref name="net-lib">Kalen Delaney, "Inside Microsoft SQL Server 2000", ''Microsoft Press'', pp. 70–74.</ref>

===OLE DB===
] (also called OLEDB or OLE-DB) allows MDAC applications access to different types of ] stores in a uniform manner. Microsoft has used this technology to separate the application from data can store in the website the data store that it needs to access. This was done because different applications need access to different types and sources of data, and do not necessarily need to know how to access technology-specific functionality. The technology is conceptually divided into ''consumers'' and ''providers''. The consumers are the applications that need access to the data, and the provider is the software component that exposes an OLE DB interface through the use of the ] (or COM).

OLE DB is the database access interface technology used by MDAC. OLE DB providers can be created to access such simple data stores as a text file or ], through to such complex databases as ] and ]. However, because different data store technology can have different capabilities, OLE DB providers may not implement every possible interface available. The capabilities that are available are implemented through the use of COM objects{{snd}} an OLE DB provider will map the data store technology's functionality to a particular COM interface. Microsoft calls the availability of an interface to be "provider-specific" as it may not be applicable depending on the database technology involved. Additionally, however, providers may also augment the capabilities of a data store; these capabilities are known as ''services'' in Microsoft parlance.

The ''Microsoft OLE DB Provider for SQL Server'' (SQLOLEDB) is the OLE DB provider that Microsoft provides for the ] from version 6.5 upwards.

===Universal data link===<!-- ###
### NOTE: This header is referenced elsewhere in Misplaced Pages.
### please be careful, if you change this you can break other
### articles and other Misplaced Pages content.
############################################################ -->
Universal data link files (or '.udl files') provide a common user interface for specifying connection attributes. A user can use a Data Link Properties ] to save connection information in a .udl file as an alternative to directly specifying them by hand in a connection string. Consequently, these files provide a convenient level of ]. Additionally, the dialog box specifies a number of alternate OLE DB data providers for a variety of target applications.<ref name="udl000">''MSDN'', , "ADO 2.8 API Reference", accessed April 28, 2007.</ref>

===ODBC===
] (ODBC) is a native interface that is accessed through a ] (usually ]) that can make calls into a ]. In MDAC this interface is defined as a DLL. A separate module or ] is needed for each database that must be accessed. The functions in the ODBC API are implemented by these DBMS-specific drivers. The driver that Microsoft provides in MDAC is called the SQL Server ODBC Driver (SQLODBC), and (as the name implies) is designed for Microsoft's SQL Server. It supports SQL Server v6.5 and upwards.<ref name="sqlodbc">'']''</ref> ODBC allows programs to use ] requests that will access databases without having to know the proprietary interfaces to the databases. It handles the SQL request and converts it into a request that the individual database system understands. According to Microsoft, "After SQL Server 2012, the ODBC driver will be updated for the most recent server features, including Microsoft Windows Azure SQL Database, and released as the Microsoft ODBC Driver for SQL Server."<ref name="sqloledb">Prash Shirolkar (Author); Alyssa Henry (contributor); Stephen Pepitone (Contributor); Acey J. Bunch (contributor); David Schwartz (contributor), , '']'', accessed March 1, 2018.</ref>

===ADO===
] ('''ADO''') is a high-level programming interface to OLE DB. It uses a hierarchical ] model to allow applications to programmatically ] data from sources supported by OLE DB. ADO consists of a series of hierarchical COM-based objects and collections, an object that acts as a container of many other objects. A programmer can directly access ADO objects to manipulate data, or can send an ] query to the database via several ADO mechanisms. ADO is made up of nine objects and four ].

The collections are:
# '''Fields:''' This collection contains a set of Field objects. The collection can be used in either a Recordset object or in a Record object. In a Recordset object, each of the Field objects that make up the Fields collection corresponds to a column in that Recordset object. In a Record object, a Field can be an absolute or relative URL that points into a tree-structured namespace (used for ] providers like the Microsoft OLE DB Provider for Internet Publishing) or as a reference to the default Stream object associated with that Record object.<ref name="adofieldscollection">''MSDN'', , "ADO 2.8 API Reference", accessed September 19, 2005.</ref>
# '''Properties:''' An object can have more than one Property object, which are contained in the object's Properties collection.<ref name="adopropertiescollection">''MSDN'', , "ADO 2.8 API Reference", accessed September 19, 2005.</ref>
# '''Parameters:''' A Command object can have several Parameter commands to change its predefined behaviour, and each of the Parameter objects are contained in the Command object's Parameters collection<ref name="adoparameterscollection">''MSDN'', , "ADO 2.8 API Reference", accessed September 19, 2005.</ref>
# '''Errors:''' All provider created errors are passed to a collection of Error objects, while the Errors collection itself is contained in a Connection object. When an ADO operation creates an error, the collection is cleared and a new group of Error objects are created in the collection.<ref name="adoerrorscollection">''MSDN'', , "ADO 2.8 API Reference", accessed September 19, 2005.</ref>

The objects are:
# '''Connection:''' The connection object is ADO's connection to a data store via OLE DB. The connection object stores information about the session and provides methods of connecting to the data store. As some data stores have different methods of establishing a connection, some methods may not be supported in the connection object for particular OLE DB providers. A connection object connects to the data store using its 'Open' method with a connection string which specifies the connection as a list of key value pairs (for example: "<code>Provider='SQLOLEDB';Data Source='TheSqlServer'; Initial Catalog='Northwind';Integrated Security='SSPI';</code>").<ref name="adoconnectionobject">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 10, 2005.</ref> The start of which must identify the type of data store connection that the connection object requires. This must be either:
#* an OLE DB provider (for example SQLOLEDB), using the syntax "provider="
#* a file name, using the syntax "file name="
#* a remote provider and server (see ]), using the syntax "Remote provider=" and "Remote server="
#* an absolute ], using the syntax "URL="<ref name="adoconnectionstring">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 10, 2005.</ref>
# '''Command:''' After the connection object establishes a session to the data source, instructions are sent to the data provider via the command object. The command object can send SQL queries directly to the provider through the use of the ''CommandText'' property, send a parameterised query or ] through the use of a ''Parameter'' object or ''Parameters'' collection or run a query and return the results to a dataset object via the ''Execute'' method. There are several other methods that can be used in the Command object relating to other objects, such as the Stream, RecordSet or Connection objects.<ref name="adocommandobject">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 10, 2005</ref>
# '''Recordset:''' A ] is a group of records, and can either come from a base table or as the result of a query to the table. The RecordSet object contains a ''Fields'' collection and a ''Properties'' collection.<ref name="adorecordsetobject">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 10, 2005.</ref> The Fields collection is a set of Field objects, which are the corresponding ] in the table. The Properties collection is a set of Property objects, which defines a particular functionality of an OLE DB provider. The RecordSet has numerous methods and properties for examining the data that exists within it.<ref name="adorecordsetobjectmethodsandproperties">A full list of ADO methods and properties that allow the examination of data in a recordset can be found in </ref> Records can be updated in the recordset by changing the values in the record and then calling on the <code>Update</code> or <code>UpdateBatch</code> method. Adding new records is performed through the <code>AddNew</code> function and then by calling on the <code>Update</code> or <code>UpdateBatch</code> method.<ref name="adoeditingdata">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 10, 2005.</ref> Records are also deleted in the recordset with the Delete method and then by calling on the Update method. <!-- the preceding couple sentence should be switched from passive to active if possible -->However, if for some reason the deletion cannot occur, such as because of violations in ], then the recordset will remain in edit mode after the call to the <code>Update</code> method. The programmer must explicitly call on the <code>CancelUpdate</code> function to cancel the update. Additionally, ADO can roll back transactions (if this is supported) and cancel batch updates.<ref name="adodelete">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 10, 2005.</ref> Recordsets can also be updated in one of three ways: via an immediate update, via a batch update,<ref name="adoimmediatevsbatch">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 12, 2005.</ref> or through the use of transactions:
## '''Immediate:''' The recordset is locked using the <code>adLockOptimistic</code> or <code>adLockPessimistic</code> lock. The data are updated at the data source after the record is changed and the <code>Update</code> method is called.
## '''Batch:''' The recordset is locked using <code>adLockBatchOptimistic</code> and each time <code>Update</code> is called the data are updated in a temporary buffer. Finally, when <code>UpdateBatch</code> is called the data are completely updated back at the data source. This has the advantage of it all being done in memory, and if a problem occurs then <code>UpdateCancel</code> is called and the updates are not sent to the data source
## '''Transaction:''' If the OLE DB provider allows it, ] can be used. To start the transaction, the programmer invokes the <code>BeginTrans</code> method and does the required updates. When they are all done, the programmer invokes the <code>CommitTrans</code> method. <code>RollbackTrans</code> can be invoked to cancel any changes made inside the transaction and ] the database to the state before the transaction began<ref name="adotransactions">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 12, 2005.</ref>
# '''Record:''' This object represents one ] in the database, and contains a fields collection. A RecordSet consists of a collection of Record objects.<ref name="adorecordobjects">''MSDN'', , "ADO 2.8 API Reference", accessed September 12, 2005.</ref>
# '''Stream:''' A stream, mainly used in a RecordSet object, is a means of reading and writing a stream of bytes.<ref name="adostreamobjects">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 12, 2005.</ref> It is mostly used to save a recordset in an XML format,<ref name="adostreamxml">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 12, 2005.</ref> to send commands to an OLE DB provider as an alternative to the CommandText object and to contain the contents of a binary or text file.
# '''Parameter:''' A parameter is a means of altering the behaviour of a common piece of functionality, for instance a stored procedure might have different parameters passed to it depending on what needs to be done; these are called ''parameterised commands''.<ref name="adoparameterobjects">''MSDN'', , "ADO 2.8 API Reference", accessed September 12, 2005.</ref>
# '''Field:''' Each Record object contains many fields, and a RecordSet object has a corresponding Field object also. The RecordSet object's Field object corresponds to a ] in the database table that it references.<ref name="adofieldobjects">''MSDN'', , "ADO 2.8 API Reference", accessed September 12, 2005.</ref>
# '''Property:''' This object is specific to the OLE DB provider and defines an ability that the provider has implemented. A property object can be either a ''built-in'' property – it is a well defined property implemented by ADO already and thus cannot be altered – or a ''dynamic'' property – defined by the underlying data provider and can be changed<ref name="adopropertyobjects">''MSDN'', "ADO 2.8 Programmers Guide", accessed September 13, 2005.</ref>
# '''Error:''' When an OLE DB provider ] occurs during the use of ADO, an Error object will be created in the Errors collection.<ref name="adoerrorobject">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 18, 2005.</ref> Other errors do not go into an Error object, however. For instance, any errors that occur when manipulating data in a RecordSet or Field object are stored in a Status property.<ref name="adorsandfielderrors">''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 18, 2005; & ''MSDN'', , "ADO 2.8 Programmers Guide", accessed September 18, 2005.</ref>

===ADO.NET===
] is the latest version of ADO (after ADO 2.8, now often referred to as ADO Classic) and is part of the MDAC 2.8 stack alongside classic ADO. It is built around ]. Though sometimes seen as an evolutionary step up from ADO, some fundamental structural changes were made by Microsoft. ADO.NET runs through a .NET Managed Provider, a modified version of an OLE DB provider specifically designed for .NET. The object structure is no longer built around a Recordset object. Instead a Dataset object is used to contain data gathered from multiple sources. This is transparent to the programmer. Unlike the old ADO Recordset, the Dataset's design promotes the use of disconnected data. Conceptually, a Dataset object can be seen as a small in-memory relational database in its own right that allows for manipulation of data in any direction. In order to propagate changes back into the database, a ] object is used that transfers data from between the data source and the DataSet object. ]s were also deprecated in ADO.NET, being replaced with a ] object, which is used to efficiently process a large list of results one record at a time without storing them.<ref name="ado.net">Doug Rothaus & Mike Pizzo, , ''MSDN'', accessed September 22, 2005.</ref>

==Deprecated and obsolete components==
MDAC is a continually evolving component framework. As such, there have been several components that were previously part of it but have since been deprecated or removed entirely from the framework.

===Jet Database Engine and JRO===
{{See also|Access Database Engine}}

Jet stands for ''Joint Engine Technology'' and was a ] used for ], ] and ]. Jet was part of a ] (RDBMS) and offered a single ] that other software could use to access Microsoft databases. Jet also provided support for security, ], ], ]ing, ] and page locking, and data replication. In later versions of Jet, the engine was extended to run ] queries, store character data in ] format, create ], and allowed bi-directional replication with the Microsoft SQL Server. It was superseded by ] which was superseded ].

There were three modules to Jet. One was the '''Native Jet ISAM Driver''', a Jet ] (DLL) that could directly manipulate Microsoft Access database files (MDB), which was a modified form of an ] (ISAM) database. Another one of the modules were the '''ISAM Drivers''', DLLs that allowed access to ISAM databases, among them being ], ], ] and ] files. The final module was the '''Data Access Objects (DAO) DLL''', ] allowed programmers access to the Jet engine. It was basically an ] data language used by Access Basic and ] application developers to access Jet.

Similarly, the ''Microsoft Jet OLE DB Provider and Replication Objects'' (JRO) which allowed replication between Jet data sources was removed from MDAC 2.6<ref name="jro">''Microsoft'', , retrieved August 5, 2005.</ref>

===MSDASQL and Oracle ODBC===
The Microsoft OLE DB Provider for ODBC, or <code>MSDASQL</code>, was an OLE DB provider for allowing ] access to databases via any ODBC driver. Microsoft supplied several OLE-DB providers (for the Indexing Service, ], Jet, SQL Server, Oracle (<code>MSDAORA</code><ref>
{{cite book
| last = Hamilton
| first = Bill
| title = ADO.NET 3.5 Cookbook
| url = https://books.google.com/books?id=akhcMCmuuw8C
| access-date = 2012-10-09
| edition = 2
| series = Cookbook Series
| year = 2008
| publisher = O'Reilly Media, Inc.
| isbn = 9780596101404
| page = 27
| quote = use the Oracle OLE DB provider (MSDAORA) to access Oracle data.
}}
</ref>)
and Internet Publishing), however unless otherwise directed, ADO defaulted to using MSDASQL as the default provider. After MDAC 2.5 both the Oracle ODBC driver and MSDASQL supported Oracle 7 and partially supported Oracle 8i. Features that were not supported were:

* ], ], ], ], ], and ] Oracle datatypes
* Unicode support for Oracle 7.x and 8i
* multiple client instances of Oracle
* nested ]s

Microsoft initially deprecated the MSDASQL component for their 64-bit operating systems<ref name="msdasql">''Microsoft'', "Data Access Technologies Road Map", Deprecated MDAC Components, ''Microsoft'' {{webarchive|url=https://web.archive.org/web/20011005101137/http://msdn.microsoft.com/library/default.asp?url=%2Flibrary%2Fen-us%2Fado270%2Fhtm%2Fmdrefodbcprovspec.asp |date=2001-10-05 }}, retrieved July 30, 2005.</ref>
and the Microsoft Oracle ODBC driver was later superseded by a .NET Managed Oracle Provider, which supported Oracle 9i.<ref name="oracleodbclimitations">
''Microsoft'', MS KB article 244661: , last reviewed August 25, 2004, retrieved August 4, 2005.</ref> However, ] and ] ship with a 64-bit version of MSDASQL.

===Remote Data Services (RDS)===
] (RDS) allowed the retrieval of a set of data from the server, which the client then altered in some way and then sent back to the server for further processing.<ref name="rds">''Microsoft'', , retrieved August 11, 2005.</ref> With the popular adoption of ], which extends SQL with such programming constructs as loops and conditional statements, this became less necessary and it was eventually deprecated in MDAC 2.7. Microsoft produced ] Toolkit 2.0, which allows clients to do this via an open ]-based standard.<ref name="rdsdeprecated">''Microsoft'', "Data Access Technologies Roadmap", "Deprecated MDAC Components"</ref>

===SQLXML===
SQLXML was designed for SQL Server 2000, but was deprecated with MDAC 2.6. It allowed Microsoft's relational database to be viewed by ] and allowed data to viewable as an ] file. It has not actually been deprecated but has been removed from later versions of MDAC, though Microsoft does provide it as a downloadable component and will support it on their 64-bit operating systems.

===Obsolete components===
Several components have been completely removed from MDAC by Microsoft and are no longer supported. They are:
* '''ESQL/C:''' ] (also known as E-SQL or ESQL/C) is a way of using SQL when programming in Visual C. Microsoft dropped support for this after SQL Server 6.5 was released, though they did license some of the ESQL/C run-time environment to a company called ], who develops ] compilers and tools<ref name="esql">Kalen Delaney, "Inside Microsoft SQL Server 2000", ''Microsoft Press'', p65.</ref>
* '''DAO:''' DAO, or ] were an ] interface created by Microsoft which allowed early versions of ] and ] to access the ]. Later (in version 3.5) it was able to bypass the Jet engine altogether and directly access ] data sources.<ref name="dao">Christine Solomon, "Microsoft Office 97 Developer's Handbook", ''Microsoft Press''. pp. 195–200.</ref>
* '''RDO:''' ], or RDO, was a ] technology that allowed for the creation of interfaces that directly called on ODBC. RDO version 2.0 was the final version developed by Microsoft.
* '''DB-Library:''' a C-based API that allowed an application to interact with SQL Server. It will not be supported on any product after SQL Server 2000, and no features were added after SQL Server 6.5.


==History== ==History==
Microsoft has released several versions of MDAC over time. The distribution method has varied and the feature-set is different for each version.
;MDAC 1.0
MDAC 1.0 was first released in August 1996 {{ref|MDAC1ReleaseDe}}. According to Microsoft, "MDAC 1.0 existed more as concept than a coordinated, stand-alone setup program." The MDAC 1.0 stack consisted of ODBC 3.0, OLE DB 1.1, ADO 1.0, and the ] (ADC) 1.0 &mdash; which according to Microsoft was the "precursor to the Remote Data Service of MDAC 1.5". It also included ODBC drivers for Access/Jet, SQL Server and ] databases. MDAC 1.0 was released via several mechanisms: the Advanced Data Connector shipped with ] (IIS) 3.0 and as a downloadable ]; OLE DB 1.1 and ADO 1.0 shipped with the OLE DB 1.1 SDK, which came with ] 97 and was also downloadable {{ref|MSKBInfo190463_1_0}}. MDAC 1.0 came with Active Server Pages, that itself came in IIS 3.0, and also came with ] 1.0 {{ref|MDACDistDe}}.


;MDAC 1.5 ===MDAC 1.0===
MDAC 1.0 was first released in August 1996.<ref name="mdac1releasede">{{in lang|de}} Christian Koller, : ''MDAC 1.0 and 1.1 (OLE DB 1.0 and OLE DB 1.1)'' accessed July 1, 2005.</ref> According to Microsoft, "MDAC 1.0 existed more as concept than a coordinated, stand-alone setup program." The MDAC 1.0 stack consisted of ODBC 3.0, OLE DB 1.1, ADO 1.0, and the ] (ADC) 1.0 &ndash; which according to Microsoft was the precursor to the Remote Data Service of MDAC 1.5. It also included ODBC drivers for Access/Jet, SQL Server and ] databases. MDAC 1.0 was released via several mechanisms: the Advanced Data Connector shipped with ] (IIS) 3.0 and as a downloadable ]; OLE DB 1.1 and ADO 1.0 shipped with the OLE DB 1.1 SDK, which came with ] 97 and was also downloadable.<ref name="mskbinfo190463">{{citation |publisher=Microsoft |url=http://support.microsoft.com/default.aspx?scid=KB;EN-US;Q190463&ID=KB;EN-US;Q190463 |title=INFO: What are MDAC, DA SDK, ODBC, OLE DB, ADO, RDS, and ADO/MD? |access-date=2005-07-01 |date=March 14, 2005}}</ref> MDAC 1.0 came with Active Server Pages, that itself came in IIS 3.0, and also came with ] 1.0.<ref name="mdac15releasede">{{citation |first=Christian |last=Koller |url=http://www.aspheute.com/artikel/20000327.htm |title=ADO und MDAC Versionen |work=MDAC 1.5 |access-date=2005-07-01|language=de}}</ref>
MDAC 1.5 was released between September 1997 and March 1998, and involved a more centralised distribution mechanism than MDAC 1.0. It was released with with Microsoft Internet Explorer 4.0 and the Internet Client SDK 4.0 and through a CD-ROM given out at the 1997 Professional Developers Conference (PDC). MDAC 1.5a was downloadable from Microsoft's website, MDAC 1.5b came with ] Option Pack and MDAC 1.5c &mdash; which fixed issues with ADO threading and ODBC Connection Pooling &mdash; could be downloaded and came with only the ADO/MDAC runtime components. MDAC 1.5d came included with ] and ] 4.01 service pack 1. {{ref|MDAC15ReleaseDe}} MDAC 1.5 consisted of ODBC 3.5, OLE DB 1.5, ADO 1.5, and the Remote Data Service 1.5, which superceded the Advanced Data Connector. {{ref|MSKBInfo190463_1_5}} This version of the MDAC had a security flaw that made it vulnerable to a ], whereby systems with both IIS and MDAC installed an otherwise unauthorized web user was able to perform execute shell commands on the IIS system as a privileged user, use MDAC to tunnel SQL and other ODBC data requests through the public connection to a private back-end network when on a ] Internet-connected IIS system, and gain unauthorized access to secured, non-published files on the IIS system {{ref|MDAC1_5SecurityFlaw}}


;MDAC 2.0 ===MDAC 1.5===
MDAC 1.5 was released between September 1997 and March 1998, and involved a more centralised distribution mechanism than MDAC 1.0. It was released with Microsoft Internet Explorer 4.0, the Internet Client SDK 4.0 and through a CD-ROM given out at the 1997 ] (PDC). There were five versions of MDAC 1.5:
MDAC 2.0 was distributed with the Data Access 2.0 SDK and included the contents of MDAC 1.5, the ODBC 3.5 SDK and the OLE DB 1.5 SDK, and the OLE DB for ] Specification; it also had included many updates to the core product {{ref|MSKBInfo190463_2_0}}, including a security feature added to the RDS which prevented it from being used maliciously an IIS server {{ref|MSKB243245}}. This version came included in Windows NT 4.0 SP4, {{ref|MDAC20DistDe}} and also with Visual Studio 6.0, which came with the full Data Access SDK {{ref|MSKBInfo190463_2_0_dist}}.
* '''MDAC 1.5 (initial release):''' included with Internet Explorer 4.0 and the Internet Client SDK.
* '''MDAC 1.5a:''' downloadable from Microsoft's website
* '''MDAC 1.5b:''' came with ] Option Pack & Office 97
* '''MDAC 1.5c:''' fixed issues with ADO threading and ODBC Connection Pooling and was distributed via the Microsoft website. It only came with the ADO/MDAC runtime components.
* '''MDAC 1.5d:''' came included with ] and ] 4.01 service pack 1.<ref name="mdac15releasede"/>


The different versions of MDAC 1.5 consisted of:
;MDAC 2.1
* ODBC 3.5
MDAC 2.1 was distributed with ] 7.0 and SQL Server 6.5 SP5; MDAC 2.1 SP1 was distributed with Internet Explorer 5; MDAC 2.1 SP1a (GA) was distributed with ] 2000, ] 4.5 and Visual Studio 98 SP3; however, none of these versions of MDAC were released to the general public via the ]. MDAC 2.1 SP2 was distributed from Microsoft's website. The components that were included with 2.1 were: ADO 2.1; RDS 2.1; OLE DB 2.1; the OLE DB Provider for ODBC, SQL Server and Oracle; Jet and Replication Objects (JRO) 2.1; an ODBC driver; a Jet driver and RDO {{ref|MDAC2_1DistDe}}.
* OLE DB 1.5
* ADO 1.5
* Remote Data Service 1.5, which superseded the Advanced Data Connector.<ref name="mskbinfo190463"/>


This version of MDAC had a security flaw that made it vulnerable to an ]. The vulnerability caused systems that had both IIS and MDAC installed to give an unauthorized web user the ability to execute shell commands on the IIS system as a privileged user. This allowed the attacker to use MDAC to tunnel SQL and other ODBC data requests through the public connection to a private back-end network when on a ] Internet-connected IIS system. It also allowed the user to gain unauthorized access to secured, non-published files on the IIS system<ref name="mdac1_5securityflaw">''Microsoft'', , accessed July 6, 2005.</ref>
This version had a security vulnerabilities whereby an unchecked buffer could allow an elevated priviledges attack. This was found some time later and it affected MDAC 2.1, 2.5 and 2.6 and was addressed in a later patch {{ref|MDAC_21_25_26_SecurityFlaw}}


MDAC 1.5 was the last data access component release supported under Windows NT 3.51 SP5.
;MDAC 2.5
MDAC 2.5 was released on ], ] and distributed with ], and the MDAC service packs were released in parallel with the Windows 2000 service packs. They were also distributed through Microsoft's website. Three service packs were released. The components that were included with 2. 5 were: ADO 2.5; ADO Multi-dimension (ADO MD) 2.5; Active Directory ADO (ADOX) 2.5; RDS 2.5; OLE DB 2.5; OLE DB Provider for the ODBC driver for SQL Server, Site Server Search, Internet Publishing, Jet 4.0 (Access 2000), Oracle, Indexing Services (Index Server), Microsoft Data Shaping Services, OLAP Services, DTS Packages, Microsoft Directory Services, SQL Server DTS Flat File, OLE DB Simple Provider; JRO 2.5; ODBC 3.51; an ODBC driver for ], SQL Server, ], Text, ], FoxPro VFP, ], dBase VFP, ] and Oracle; Jet drivers for Excel, ], Access, text files, ], Pardox and ] {{ref|MDAC2_5DistDe}}.


===MDAC 2.0===
Several issues were found in this version of MDAC. When using OLE DB Session Pooling, Microsoft ] would try to continuously load and unload ODL DB, and a conflict could arise that caused the OLE DB Session Pooling to run at 100% CPU usage. This was later fixed. {{ref|MSKB320700}} Microsoft published a full list of bugs fixed in and . A security vulnerability also existed (later fixed) whereby an unchecked buffer in was found in the SQL Server Driver. This flaw was introduced in MDAC 2.5 SP2.
MDAC 2.0 was distributed with the Data Access 2.0 SDK and included the contents of MDAC 1.5, the ODBC 3.5 SDK and the OLE DB 1.5 SDK, and the OLE DB for ] Specification. It also had included many updates to the core product,<ref name="mskbinfo190463"/> including a security feature added to the RDS which prevented it from being used maliciously an IIS server.<ref name="mskb243245">''Microsoft'', (last reviewed September 30, 2003), accessed July 6, 2005; : "Unauthorized ODBC Data Access with RDS and IIS" (last revision: July 17, 1998), accessed July 6, 2005; CVE vulnerability {{CVE|1999-1011}}.</ref> This version came included in Windows NT 4.0 SP4,<ref name="mdac20distde">Christian Koller, : MDAC 2.0, accessed July 1, 2005.</ref> and also with Visual Studio 6.0, which came with the full Data Access SDK.<ref name="mskbinfo190463"/>


;MDAC 2.6 ===MDAC 2.1===
MDAC 2.1 was distributed with ] 7.0 and SQL Server 6.5 SP5. MDAC 2.1 SP1 was distributed with Internet Explorer 5 and MDAC 2.1 SP1a (GA) was distributed with ] 2000, ] 4.5 and Visual Studio 98 SP3. However, none of these versions of MDAC were released to the general public via the ]. MDAC 2.1 SP2 was distributed from Microsoft's website. The components that were included with 2.1 were:
MDAC 2.6 was released in September 2000 and was distributed through the web and with Microsoft SQL Server 2000 {{ref|MDAC2_6ReleaseManifest}} MDAC 2.6 RTM, SP1 (released ], ]), and SP2 (released ], ]) were distributed in parallel with the Microsoft SQL Server 2000 service packs, and could also be downloaded from the Microsoft website.
* ADO 2.1
* RDS 2.1
* OLE DB 2.1
* the OLE DB Provider for ODBC, SQL Server and Oracle
* JRO 2.1
* a Jet driver
* RDO.<ref name="mdac2_1distde">{{in lang|de}} Christian Koller, : MDAC 2.1, accessed July 1, 2005.</ref>


This version had security vulnerabilities whereby an unchecked buffer could allow an elevated privileges attack. This was found some time later and it affected MDAC 2.1, 2.5 and 2.6 and was addressed in a later patch<ref name="mdac_21_25_26_securityflaw">''Microsoft'', "Data Access Components: Security Hotfix for Q329414"; &ndash; originally Microsoft KB article Q329414) &ndash; (originally posted November 20, 2002), accessed July 6, 2005.</ref>
Beginning with this version of MDAC, Microsoft Jet, Microsoft Jet OLE DB Provider, and the ODBC Desktop Database Drivers were not included. Instead, these could be installed manually. {{ref|MSKB271908NoJet}} Microsoft also released an alert warning that MDAC 2.6 should not be installed on an SQL Server 7.0 Cluster, because "if you install MDAC 2.6 or later on any node in the cluster, directly or through the installation of another program, it may cause a catastrophic failure of the SQL Server Agent or other SQL Server services." {{ref|MSKB820754SQLServer7_0Cluster}} This issue effected ]'s Backup Exec 9.0 for Windows Servers, because it installs Microsoft SQL Server 2000 Desktop Engine (MSDE 2000) as its database. Revision 4367 installed MDAC version 2.6 SP2 while revision 4454 installed MDAC version 2.7 SP1, which did not have the problem {{ref|Veritas}}


;MDAC 2.7 ===MDAC 2.5===
MDAC 2.5 was released on February 17, 2000, and distributed with ], and the MDAC service packs were released in parallel with the Windows 2000 service packs. They were also distributed through Microsoft's website. Three service packs were released. The components included with 2.5 were:
MDAC 2.7 was released in October 2001 through Microsoft's website. A refresh release was issued in April 2002 through the release of Windows XP and through Microsoft's website. Version 2.7 was available in ], ] (Traditional and Simplified), ], ], ], ], ], ], ], ], ], ], ], ], ], ], ], ], ], ], ], ], and ]. ] and ] were only available through Windows XP.
* ADO 2.5
* ADO MD 2.5
* ADOX 2.5
* RDS 2.5
* OLE DB 2.5
* many OLE DB Providers
* JRO 2.5
* ODBC 3.51
* many ODBC drivers
* many Jet drivers.<ref name="mdac2_5distde">{{in lang|de}} Christian Koller, : MDAC 2.5, accessed July 1, 2005.</ref>


Several issues were found in this version of MDAC. When using OLE DB Session Pooling, Microsoft ] would try to continuously load and unload OLE DB, and a conflict could arise that caused the OLE DB Session Pooling to run at 100% CPU usage. This was later fixed.<ref name="mskb320700">''Microsoft'', MS KB article 320700, , accessed July 6, 2005.</ref> Microsoft published a full list of bugs fixed in and . A security vulnerability also existed (later fixed) whereby an unchecked buffer was found in the SQL Server Driver. This flaw was introduced in MDAC 2.5 SP2.
The main feature change was support for Microsoft's ] operating system, however support for ] was also dropped from this version of MDAC. There were several known issues {{ref|MSKB842280MDAC2_7Manifest}}: MDAC 2.7 continued causing connectivity problems on clustered servers running Microsoft SQL Server 6.5 or SQL Server 7.0, with no workaround provided by Microsoft. When creating or configuring ODBC ] (DSNs) using the Microsoft SQL Server ODBC driver the network library protocol might unexpectedly switch to ], even if the DSN was configured to use ]. {{ref|MSKB289573}} Windows XP users also sometimes experienced problems connecting to SQL Server because SQL Server attempts to use certificates it finds on the local computer, however if there is more than one certificate available it did not know which one to use. {{ref|MSKB309398}} When attempting to use ] 2000 RTM, an error would sometimes appear when trying to browse cubes. {{ref|MSKB297232}} Microsoft also discovered a problem in a ], ], and ]'s setup program which prevented the MDAC installation program from rolling back when it encountered an installation error. {{ref|MSKB311720}}


===MDAC 2.6===
Several security issues were resolved by Microsoft for MDAC 2.7. ] of ] reported a security vulnerability that results because one of the ODBC functions in MDAC that is used to connect to data sources contained an unchecked buffer. {{ref|MS02-040}} Another vulnerability that was fixed was one whereby an attacker could respond to an SQL Server discovery message broadcasted by clients with a specially crafted packet that could cause a buffer overflow. {{ref|MS03-033}} Another flaw was found whereby code could be executed remotely when the attack responded to the broadcast with another specially crafted packet {{ref|MS04-003}}.
MDAC 2.6 was released in September 2000 and was distributed through the web and with Microsoft SQL Server 2000<ref name="mdac2_6releasemanifest">''Microsoft'', MS KB article 842272 , accessed July 6, 2005.</ref> MDAC 2.6 RTM, SP1 (released June 20, 2001), and SP2 (released June 11, 2002) were distributed in parallel with the Microsoft SQL Server 2000 service packs, and could also be downloaded from the Microsoft website.


Beginning with this version of MDAC, Microsoft Jet, Microsoft Jet OLE DB Provider, and the ODBC Desktop Database Drivers were not included. Instead, these could be installed manually.<ref name="mskb271908nojet">''Microsoft'', MS KB article 271908 , accessed July 6, 2005.</ref> Microsoft also released an alert warning that MDAC 2.6 should not be installed on an SQL Server 7.0 Cluster, because "if you install MDAC 2.6 or later on any node in the cluster, directly or through the installation of another program, it may cause a catastrophic failure of the SQL Server Agent or other SQL Server services."<ref name="mskb820754sqlserver7_0cluster">''Microsoft'', MS KB article 820754 , accessed July 6, 2005.</ref> This issue affected ]'s Backup Exec 9.0 for Windows Servers, because it installs Microsoft SQL Server 2000 Desktop Engine (MSDE 2000) as its database. Revision 4367 installed MDAC version 2.6 SP2 while revision 4454 installed MDAC version 2.7 SP1, which did not have the problem<ref name="veritas">''Veritas'', Document ID: 258144 {{webarchive|url=https://archive.today/20130105153934/http://seer.support.veritas.com/docs/258144.htm |date=2013-01-05 }}</ref>
;MDAC 2.8
MDAC 2.8 was released in August 2003 and distributed with Microsoft ], as well as on Microsoft's website. It did not introduce any new features to the product but fixed a number of bugs and security issues &mdash; a reg file (automates changes to the registry) was removed that made the server run in an "unsafe" mode whereby the RDS could be exploited to gain unauthorised access to the system {{ref|Handunsf_reg}} and a new restriction was is imposed on the length of the Shape query string {{ref|ShapeQueryStringLimit}}. There were also several ODBC Administrator changes. {{ref|ODBCAdministratorChanges}}


==Notes== ===MDAC 2.7===
MDAC 2.7 was released in October 2001 through Microsoft's website. A refresh release was issued in April 2002 through the release of Windows XP and through Microsoft's website. Version 2.7 was available in ], Chinese (Traditional and Simplified), German, Japanese, Korean, ], ], Danish, Greek, ], ], Spanish, Finnish, French, Hungarian, Italian, ], Norwegian, Polish, Portuguese, Russian, Swedish, and ]. ] and ] were only available through Windows XP.
<div style="font-size: 75%">

# {{note|MDAC1ReleaseDe}} Christian Koller, : ''MDAC 1.0 and 1.1 (OLE DB 1.0 and OLE DB 1.1)'' accessed July 1, 2005.
The main feature change was support for Microsoft's ] operating system, however support for ] was also dropped from this version of MDAC. There were several known issues:<ref name="mskb842280mdac2_7manifest">{{cite web|url=http://support.microsoft.com/default.aspx?scid=kb;EN-US;842280 |title=Release manifest for MDAC 2.7 Refresh (2.70.9001.0) |publisher=Support.microsoft.com |access-date=2019-04-10}}</ref> MDAC 2.7 continued causing connectivity problems on clustered servers running Microsoft SQL Server 6.5 or SQL Server 7.0, with no workaround provided by Microsoft. When creating or configuring ODBC ] (DSNs) using the Microsoft SQL Server ODBC driver the network library protocol might unexpectedly switch to ], even if the DSN was configured to use ].<ref name="mskb289573">''Microsoft'', MS KB article 289573 </ref> This issue was found by '']'' reporter ], who identified that the change was actually made in MDAC 2.6 but was never documented. It was discovered when testing client/server database workloads on a Windows XP computer; ''InfoWorld'' claims that although overall server CPU utilization rose by only 8 percent using TCP/IP, ]es per second dropped by more than 150 percent (which is of course impossible because you would then have a negative context switch rate - the drop is either 33% or 60% depending on which planet the author was on at the time of writing) for a 10-user workload. They were unimpressed that a fundamental functional change to the default behaviour of Net-Lib occurred without more than a passing mention in an unrelated document.<ref name="infoworldnetlibissue">{{cite web |url=http://www.infoworld.com/articles/tc/xml/01/11/26/011126tcmdac.html |title=It's not a bug, it's a feature |work=] |publisher=] |first=Randall C. |last=Kennedy |date=21 November 2001 |archive-url=https://web.archive.org/web/20070310235442/http://www.infoworld.com/articles/tc/xml/01/11/26/011126tcmdac.html |archive-date=10 March 2007}}</ref> Windows XP users also sometimes experienced problems connecting to SQL Server because SQL Server attempts to use ]s it finds on the local computer, however if there is more than one certificate available it did not know which one to use.<ref name="mskb309398">''Microsoft'', MS KB article 309398 </ref> When attempting to use ] 2000 RTM, an error would sometimes appear when trying to browse cubes.<ref name="mskb297232">''Microsoft'', MS KB article 297232 </ref> Microsoft also discovered a problem in ], ], and ]'s setup program which prevented the MDAC installation program from rolling back when it encountered an installation error.<ref name="mskb311720">''Microsoft'', MS KB article 311720 </ref>
# {{note|MSKBInfo190463_1_0}} ''Microsoft'', : The MDAC 1.0 Stack (last reviewed March 14, 2005), accessed July 1, 2005.

# {{note|MDACDistDe}} Christian Koller, , accessed July 1, 2005.
Several security issues were resolved by Microsoft for MDAC 2.7. ] of ] reported a security vulnerability that results because one of the ODBC functions in MDAC that is used to connect to data sources contained an unchecked buffer.<ref name="ms02-040">''Microsoft'', .</ref> Another vulnerability that was fixed was one whereby an attacker could respond to an SQL Server discovery message broadcast by clients with a specially crafted packet that could cause a buffer overflow.<ref name="ms03-033">''Microsoft'', </ref> Another flaw was found whereby code could be executed remotely when the attacker responded to the broadcast with another specially crafted packet.<ref name="ms04-003">''Microsoft'', </ref>
# {{note|MDAC15ReleaseDe}} Christian Koller, : ''MDAC 1.5'', accessed July 1, 2005.

# {{note|MSKBInfo190463_1_5}} ''Microsoft'', : The MDAC 1.5 Stack (last reviewed March 14, 2005), accessed July 1, 2005.
===MDAC 2.8===
# {{note|MDAC1_5SecurityFlaw}} ''Microsoft'', , accessed July 6, 2005.
MDAC 2.8 was released in August 2003 and distributed with Microsoft ], as well as on Microsoft's website. It did not introduce any new features to the product but fixed a number of bugs and security issues &ndash; a reg file (automates changes to the registry) was removed that made the server run in an "unsafe" mode whereby the RDS could be exploited to gain unauthorized access to the system<ref name="handunsf_reg">''Microsoft''. MS KB article 818490: </ref> and a new restriction was imposed on the length of the Shape query string.<ref name="shapequerystringlimit">''Microsoft''. MS KB article 838405: </ref> There were also several ODBC Administrator changes.<ref name="odbcadministratorchanges">''Microsoft''. MS KB article 818489, .</ref>
# {{note|MSKBInfo190463_2_0}} ''Microsoft'', : The MDAC 2.0 Stack (last reviewed March 14, 2005), accessed July 6, 2005.

# {{note|MSKB243245}} ''Microsoft'', (last reviewed September 30, 2003), accessed July 6, 2005; : "Unauthorized ODBC Data Access with RDS and IIS" (last revision: July 17, 1998), accessed July 6, 2005; ] vulnerability .
On May 23, 2005, Brad Rhodes (Lead Program Manager of Microsoft Data Access Technologies) announced that MDAC 2.8 SP1 was the last stand-alone redistributable of MDAC that Microsoft will ship. MDAC is now an official component of the Microsoft's operating system, though they will be providing ongoing bug and security fixes to previously released versions of the web-distributable version.<ref name="bradrhodesstandalonedistributable">Brad Rhodes (blog entry), , May 23, 2005, retrieved August 11, 2005; & ''Microsoft'', MS KB article 892854: , last updated January 24, 2005, retrieved August 11, 2005.</ref> However, Microsoft have created a new component called the ] (SQLNCLI), which is a stand-alone data access API that has combined the OLE DB and ODBC libraries into one DLL. It was formed to be independent of MDAC, which is now reliant on the state the operating system is in &ndash; a developer now links to this library and avoids situations where an update of the operating system which updates MDAC breaks applications built to a different version of MDAC.<ref name="sqlncli">Acey J. Bunch (April 26, 2005), , ''MSDN'' ] entry.</ref>
# {{note|MDAC20DistDe}} Christian Koller, : MDAC 2.0, accessed July 1, 2005.

# {{note|MSKBInfo190463_2_0_dist}} ''Microsoft'', : The MDAC 2.0 Stack (last reviewed March 14, 2005), accessed July 6, 2005.
] SP1 has broken ] of MDAC 2.8. Software compiled on Windows 7 SP1 that relies on MDAC ADO will not work on Windows versions prior to Windows 7 SP1 (including Windows 7 RTM, Vista, XP).<ref name="msdnforum">''MSDN'', , "Forum", accessed March 9, 2011.</ref> Microsoft has provided solutions to work around this issue for some applications but VBA applications remain affected.<ref name="kb2517589">''KB 2517589'', , "", accessed March 17, 2011.</ref> The fix for this issue has been release in February 2012.<ref name="kb2640696">''KB 2640696'', , "", accessed April 20, 2012.</ref>
# {{note|MDAC2_1DistDe}} Christian Koller, : MDAC 2.1, accessed July 1, 2005.

# {{note|MDAC_21_25_26_SecurityFlaw}} ''Microsoft'', (download page); &mdash; originally Microsoft KB article Q329414) &mdash; (originally posted November 20, 2002), accessed July 6, 2005.
===Windows DAC 6.0===
# {{note|MDAC2_5DistDe}} Christian Koller, : MDAC 2.5, accessed July 1, 2005.
] will no longer use MDAC, but instead use Windows DAC, which consists of updated versions of ADO, OLE DB, and ODBC components. According to Microsoft, "Windows DAC includes some changes to work with Windows Vista, but is almost entirely functionally equivalent to MDAC 2.8."<ref name="WDAC">'']'', . Accessed 12th December, 2006.</ref>
# {{note|MSKB320700}} ''Microsoft'', MS KB article 320700, , accessed July 6, 2005.

# {{note|MDAC2_6ReleaseManifest}} ''Microsoft'', MS KB article 842272 , accessed July 6, 2005.
===Version checking===
# {{note|MSKB271908NoJet}} ''Microsoft'', MS KB article 271908 , accessed July 6, 2005.
There are two ways of checking the version of MDAC that is installed on a computer. For Windows 2000, Windows XP and Windows Server 2003, one way to check is via Microsoft's program, which compares the value of each installed MDAC DLL to the MDAC file manifest. The second way is to check the key <code>HKEY_LOCAL_MACHINE\Software\Microsoft\DataAccess\FullInstallVer</code> in the ]. Microsoft notes that this information may be incorrect for versions of MDAC prior to 2.1 when compared with the versions of the MDAC files installed to the system<ref name="versionchecking">''Microsoft''. MS KB article 301202, , last updated January 18, 2005, retrieved September 29, 2005.</ref>
# {{note|MSKB820754SQLServer7_0Cluster}} ''Microsoft'', MS KB article 820754 , accessed July 6, 2005.

# {{note|Veritas}} ''Veritas'', Document ID: 258144
{| class=wikitable
# {{note|MSKB289573}} ''Microsoft'', MS KB article 289573
|-
# {{note|MSKB842280MDAC2_7Manifest}}
! style="width:10%;"| Version
# {{note|MSKB309398}} ''Microsoft'', MS KB article 309398
! style="width:10%;"| Release date
# {{note|MSKB297232}} ''Microsoft'', MS KB article 297232
! style="width:40%;"| Included with
# {{note|MSKB311720}} ''Microsoft'', MS KB article 311720
! style="width:15%;"| Features
# {{note|MS02-040}} ''Microsoft'', .
! style="width:10%;"| Security issues
# {{note|MS03-033}} ''Microsoft'',
|-
# {{note|MS04-003}} ''Microsoft'',
| 1.0
# {{note|Handunsf_reg}} ''Microsoft''. MS KB article 818490:
| August 1996
# {{note|ShapeQueryStringLimit}} ''Microsoft''. MS KB article 838405:
|
# {{note|ODBCAdministratorChanges}} ''Microsoft''. MS KB article 818489, .
* ADC – IIS 3.0
</div>
* OLE DB 1.1 SDK (OLE DB 1.1 and ADO 1.0) – Visual Studio
* All components included in Visual Interdev 1.0 and with Active Server Pages (released in IIS 3.0)
|
* ODBC 3.0
* OLE DB 1.1
* ADO 1.0
* ADC 1.0
* ODBC drivers for Access/Jet, SQL Server and Oracle databases
|
No bulletins released
|-
|
1.5
| September 1997 – March 1998
|
* Microsoft Internet Explorer 4.0
* Internet Client SDK 4.0 (from CD issued at Microsoft PDC)
|
* ODBC 3.5
* OLE DB 1.5
* ADO 1.5
* RDS 1.5 (superseded ADC 1.0)
| ROWSPAN=4 |
* {{mssb|99|025}}
|-
| 1.5a
| September 1997–March 1998
|
|
Service release
|-
| 1.5b
| September 1997–March 1998
|
* ] Option Pack
* ] 97
|
Service release
|-
| 1.5c
| September 1997–March 1998
|
|
* Fixed issues with ADO threading and ODBC Connection Pooling
* Only came with ADO/MDAC runtime components
|-
| 2.0
| July 1, 1998
|
* Visual Studio 98
* Data Access 2.0 SDK
|
* ODBC 3.5 SDK
* OLE DB 1.5 SDK
* OLE DB for OLAP Specification
| ROWSPAN=3 |
* {{mssb|98|004}}
|-
| 2.0SP1
| July 1, 1998
|
* Windows NT 4.0 SP4
|
Y2K remediation for Windows NT 4.0
|-
| 2.0SP2
| July 1, 1998
|
* Microsoft website
|
Y2K remediation for all platforms
|-
| 2.1
| July 11, 1998
|
* SQL Server 7.0
* SQL Server 6.5 SP5
| ROWSPAN=4 |
* ADO 2.1
* RDS 2.1
* OLE DB 2.1
* OLE DB Provider for ODBC, SQL Server and Oracle
* JRO 2.1
* ODBC driver
* Jet driver
* RDO
| ROWSPAN=4 |
* {{mssb|02|065}}
|-
| 2.1 SP1
| March 15, 1999
|
* Internet Explorer 5.0
* Windows 98 Second Edition
|-
| 2.1 SP1a (GA)
| April 1, 1999
|
* Office 2000
* BackOffice 4.5
* Visual Studio 98 SP3
* Internet Explorer 5.0a (minimal install)
|-
| 2.1 SP2
| July 1999
|
|-
| 2.5
| February 17, 2000
|
* Windows 2000
| ROWSPAN=4 |
* ADO 2.5
* ADO MD 2.5
* ADOX 2.5
* RDS 2.5
* OLE DB 2.5
* OLE DB Provider for the ODBC driver for:
** SQL
** Server
** Site Server Search
** Internet Publishing
** Jet 4.0 (Access 2000)
** Oracle
** Indexing Services (Index Server)
** Microsoft Data Shaping Services
** OLAP Services
** DTS Packages
** Microsoft Directory Services
** Server DTS Flat File
** OLE DB Simple Provider
* JRO 2.5
* ODBC 3.51
* an ODBC driver for
** Microsoft Access
** SQL Server
** Microsoft Excel
** Text
** Visual FoxPro
** FoxPro VFP
** dBase
** dBase VFP
** Paradox
** Oracle
* Jet drivers for:
** Excel
** Microsoft Exchange
** Access
** text files
** Lotus 1-2-3
** Paradox
** xBase
| ROWSPAN=4 |
* {{mssb|02|065}}
|-
| 2.5 SP1
| July 31, 2000
|
* Windows 2000 SP1
|-
| 2.5 SP2
| April 2000
|
* Windows 2000 SP2
|-
| 2.5 SPS3
| December 2003
|
* Windows 2000 SP3
|-
| 2.6
| September 2000
|
* SQL Server 2000
| ROWSPAN=3 | Not included (manually installed):
* Microsoft Jet
* Microsoft Jet OLE DB Provider
* ODBC Desktop Database Drivers
| ROWSPAN=3 |
* {{mssb|02|065}}
|-
| 2.6 SP1
| May 2001
|
* SQL Server 2000 SP1
|-
| 2.6 SP2
| May 2002
|
* SQL Server 2000 SP2
|-
| 2.7
| October 2001
|
* Windows XP
|
* Support for 64-bit operating systems
* ] support dropped
|
* {{mssb|02|065}}
* {{mssb|02|040}}
* {{mssb|03|033}}
* {{mssb|04|003}}
|-
| 2.8
| August 2003
|
* Windows Server 2003
|
Fixed bugs and security issues
|
* {{mssb|03|033}}
* {{mssb|04|003}}
|-
| 2.8 SP1
| May 2005
|
* SQL Server 2000 SP4
* Windows XP SP2
|
Fixed bugs
|
|-
| 2.8 SP2
| March 2005
|
* Windows Server 2003 SP1
|
|-
| 9.0
| Never released
|
* Visual Studio 2005 Beta 1 (Removed in subsequent releases)
* SQL Server 2005 Beta 1 (Removed in subsequent releases)<ref>, supplementary material to "A First Look at SQL Server 2005 for Developers" by Bob Beauchemin, Niels Berglund, and Dan Sullivan. {{webarchive |url=https://web.archive.org/web/20060324134243/http://staff.develop.com/bobb/sql2005book/changes11.htm |date=March 24, 2006 }}</ref>
|
|
|-
| Windows DAC 6.0 (a variant of MDAC for use with Vista)
| November 2006
|
* ]
|
* Version number synchronized with Windows version
* No other new features
|
|}

==References==
{{Reflist |30em}}

==Further reading==
{{Refbegin}}
* {{cite web |title=ADO API Reference |url=http://msdn.microsoft.com/en-us/library/windows/desktop/ms678086%28v=vs.85%29.aspx |work=] |publisher=] |access-date=3 May 2014}}
* {{cite web |title=ADO Programmer's Guide |url=http://msdn.microsoft.com/en-us/library/windows/desktop/ms681025%28v=vs.85%29.aspx |work=] |publisher=] |access-date=3 May 2014}}
* {{cite book |last=Delaney |first=Kalen |title=Inside Microsoft SQL Server 2000 |year=2000 |publisher=] |edition=3 |isbn=9780735609983 |url-access=registration |url=https://archive.org/details/insidemicrosofts00dela }}
* {{cite web |last=Rothaus |first=Doug |last2=Mike |first2=Pizzo |title=ADO.NET for the ADO Programmer |url=http://msdn.microsoft.com/en-us/library/ms973217.aspx |work=] |publisher=] |access-date=3 May 2014 |date=December 2001}}
* {{cite web |first=Prash |last=Shirolkar |first2=Alyssa |last2=Henry |first3=Stephen |last3=Pepitone |first4=Acey J. |last4=Bunch |first5=David |last5=Schwartz |title=Data Access Technologies Road Map |url=http://msdn.microsoft.com/en-us/library/ms810810.aspx |work=] |publisher=] |access-date=3 May 2014 |date=January 2013}}
* {{cite book |last=Solomon |first=Christine |title=Microsoft Office 97 Developer's Handbook |url=https://archive.org/details/microsoftoffice900solo |url-access=registration |year=1997 |publisher=] |isbn=9781572316065}}
{{Refend}}


==External links== ==External links==
* http://msdn.microsoft.com/data/mdac/default.aspx *
*
*

{{Microsoft APIs}}


]
{{windows-stub}}

Latest revision as of 08:52, 30 May 2024

Framework
This article has an unclear citation style. The references used may be made clearer with a different or consistent style of citation and footnoting. (August 2013) (Learn how and when to remove this message)
Microsoft Data Access Components
MDAC provides a uniform framework for accessing a variety of data sources on their Windows platform
Developer(s)Microsoft
Final release2.8 SP1 (2.81.1117.6) / May 2005
Operating systemWindows 98, Windows ME, Windows NT 4, Windows 2000, Windows XP, Windows Server 2003, Windows 7, Windows 10
TypeDatabase
LicenseFreeware
Websitemsdn2.microsoft.com/en-us/data/aa937729.aspx

Microsoft Data Access Components (MDAC; also known as Windows DAC) is a framework of interrelated Microsoft technologies that allows programmers a uniform and comprehensive way of developing applications that can access almost any data store. Its components include: ActiveX Data Objects (ADO), OLE DB, and Open Database Connectivity (ODBC). There have been several deprecated components as well, such as the Jet Database Engine, MSDASQL (the OLE DB provider for ODBC), and Remote Data Services (RDS). Some components have also become obsolete, such as the former Data Access Objects API and Remote Data Objects.

The first version of MDAC was released in August 1996. At that time Microsoft stated MDAC was more a concept than a stand-alone program and had no widespread distribution method. Later Microsoft released upgrades to MDAC as web-based redistributable packages. Eventually, later versions were integrated with Microsoft Windows and Internet Explorer, and in MDAC 2.8 SP1 they ceased offering MDAC as a redistributable package.

Throughout its history, MDAC has been the subject of several security flaws, which led to attacks such as an escalated privileges attack, although the vulnerabilities were generally fixed in later versions and fairly promptly. The current version is 2.8 service pack 1, but the product has had many different versions and many of its components have been deprecated and replaced by newer Microsoft technologies. MDAC is now known as Windows DAC in Windows Vista.

Architecture

The latest version of MDAC (2.8) consists of several interacting components, all of which are Windows specific except for ODBC (which is available on several platforms). MDAC architecture may be viewed as three layers: a programming interface layer, consisting of ADO and ADO.NET, a database access layer developed by database vendors such as Oracle and Microsoft (OLE DB, .NET managed providers and ODBC drivers), and the database itself. These component layers are all made available to applications through the MDAC API. The Microsoft SQL Server Network Library, a proprietary access method specific to Microsoft SQL Server, is also included in the MDAC. Developers of Windows applications are encouraged to use ADO or ADO.NET for data access, the benefit being that users of the application program are not constrained in their choice of database architecture except that it should be supported by MDAC. Naturally, developers still have the choice of writing applications which directly access OLE DB and ODBC.

Microsoft SQL Server Network Library

The Microsoft SQL Server Network Library (also known as Net-Lib) is used by the Microsoft SQL Server to read and write data using many different network protocols. Though Net-Lib is specific to the SQL Server, Microsoft includes it with MDAC. The SQL Server uses the Open Data Services (ODS) library to communicate with Net-Lib, which interfaces directly with the Windows NT operating system line's Win32 subsystem. The SQL Server Network Library is controlled through the use of a Client Network Utility, which is bundled with the SQL Server.

Each Net-Lib supported network protocol has a separate driver (not to be confused with a device driver), and has support for a session layer in its protocol stack. There are two general types of Net-Lib: the primary and the secondary. The primary Net-Lib consists of a Super Socket Net-Lib and the Shared Memory Net-Lib, while there are numerous secondary Net-Libs, including TCP/IP and named pipes network libraries (named pipes are a method of communicating with other processes via a system-persistent pipeline that is given an identity). The Microsoft OLE DB Provider for SQL Server (SQLOLEDB) communicates via primary Net-Libs.

The Super Socket Net-Lib deals with inter-computer communications and coordinates the secondary Net-Libs – though the TCP/IP secondary Net-Lib is an exception in that it calls on the Windows Sockets 2 API directly. The Banyan VINES, AppleTalk, ServerNet, IPX/SPX, Giganet, and RPC Net-Libs were dropped from MDAC 2.5 onwards. The Network Library router had the job of managing all these protocols, however now only the named pipes secondary Net-Lib is managed by the router. The Super Socket Net-Lib also handles data encryption via the use of the Windows SSL API.

The Shared Memory Net-Lib, on the other hand, manages connections between multiple instances of SQL Server that exist on one computer. It uses a shared memory area to communicate between the processes. This is inherently secure; there is no need for data encryption between instances of SQL Server that exist on one computer as the operating system does not allow any other process access to the instances' area of shared memory.

Net-Lib is also able to support the impersonation of a logged in user's security context for protocols that support authenticated connections (called trusted connections). This allows Net-Lib to provide an integrated logon authentication mechanism via the use of Windows Authentication. Windows Authentication is not supported on Windows 98 or Windows Me.

OLE DB

OLE DB (also called OLEDB or OLE-DB) allows MDAC applications access to different types of data stores in a uniform manner. Microsoft has used this technology to separate the application from data can store in the website the data store that it needs to access. This was done because different applications need access to different types and sources of data, and do not necessarily need to know how to access technology-specific functionality. The technology is conceptually divided into consumers and providers. The consumers are the applications that need access to the data, and the provider is the software component that exposes an OLE DB interface through the use of the Component Object Model (or COM).

OLE DB is the database access interface technology used by MDAC. OLE DB providers can be created to access such simple data stores as a text file or spreadsheet, through to such complex databases as Oracle and SQL Server. However, because different data store technology can have different capabilities, OLE DB providers may not implement every possible interface available. The capabilities that are available are implemented through the use of COM objects – an OLE DB provider will map the data store technology's functionality to a particular COM interface. Microsoft calls the availability of an interface to be "provider-specific" as it may not be applicable depending on the database technology involved. Additionally, however, providers may also augment the capabilities of a data store; these capabilities are known as services in Microsoft parlance.

The Microsoft OLE DB Provider for SQL Server (SQLOLEDB) is the OLE DB provider that Microsoft provides for the Microsoft SQL Server from version 6.5 upwards.

Universal data link

Universal data link files (or '.udl files') provide a common user interface for specifying connection attributes. A user can use a Data Link Properties dialog box to save connection information in a .udl file as an alternative to directly specifying them by hand in a connection string. Consequently, these files provide a convenient level of indirection. Additionally, the dialog box specifies a number of alternate OLE DB data providers for a variety of target applications.

ODBC

Open Database Connectivity (ODBC) is a native interface that is accessed through a programming language (usually C) that can make calls into a native library. In MDAC this interface is defined as a DLL. A separate module or driver is needed for each database that must be accessed. The functions in the ODBC API are implemented by these DBMS-specific drivers. The driver that Microsoft provides in MDAC is called the SQL Server ODBC Driver (SQLODBC), and (as the name implies) is designed for Microsoft's SQL Server. It supports SQL Server v6.5 and upwards. ODBC allows programs to use SQL requests that will access databases without having to know the proprietary interfaces to the databases. It handles the SQL request and converts it into a request that the individual database system understands. According to Microsoft, "After SQL Server 2012, the ODBC driver will be updated for the most recent server features, including Microsoft Windows Azure SQL Database, and released as the Microsoft ODBC Driver for SQL Server."

ADO

ActiveX Data Objects (ADO) is a high-level programming interface to OLE DB. It uses a hierarchical object model to allow applications to programmatically create, retrieve, update and delete data from sources supported by OLE DB. ADO consists of a series of hierarchical COM-based objects and collections, an object that acts as a container of many other objects. A programmer can directly access ADO objects to manipulate data, or can send an SQL query to the database via several ADO mechanisms. ADO is made up of nine objects and four collections.

The collections are:

  1. Fields: This collection contains a set of Field objects. The collection can be used in either a Recordset object or in a Record object. In a Recordset object, each of the Field objects that make up the Fields collection corresponds to a column in that Recordset object. In a Record object, a Field can be an absolute or relative URL that points into a tree-structured namespace (used for semi-structured data providers like the Microsoft OLE DB Provider for Internet Publishing) or as a reference to the default Stream object associated with that Record object.
  2. Properties: An object can have more than one Property object, which are contained in the object's Properties collection.
  3. Parameters: A Command object can have several Parameter commands to change its predefined behaviour, and each of the Parameter objects are contained in the Command object's Parameters collection
  4. Errors: All provider created errors are passed to a collection of Error objects, while the Errors collection itself is contained in a Connection object. When an ADO operation creates an error, the collection is cleared and a new group of Error objects are created in the collection.

The objects are:

  1. Connection: The connection object is ADO's connection to a data store via OLE DB. The connection object stores information about the session and provides methods of connecting to the data store. As some data stores have different methods of establishing a connection, some methods may not be supported in the connection object for particular OLE DB providers. A connection object connects to the data store using its 'Open' method with a connection string which specifies the connection as a list of key value pairs (for example: "Provider='SQLOLEDB';Data Source='TheSqlServer'; Initial Catalog='Northwind';Integrated Security='SSPI';"). The start of which must identify the type of data store connection that the connection object requires. This must be either:
    • an OLE DB provider (for example SQLOLEDB), using the syntax "provider="
    • a file name, using the syntax "file name="
    • a remote provider and server (see RDS), using the syntax "Remote provider=" and "Remote server="
    • an absolute URL, using the syntax "URL="
  2. Command: After the connection object establishes a session to the data source, instructions are sent to the data provider via the command object. The command object can send SQL queries directly to the provider through the use of the CommandText property, send a parameterised query or stored procedure through the use of a Parameter object or Parameters collection or run a query and return the results to a dataset object via the Execute method. There are several other methods that can be used in the Command object relating to other objects, such as the Stream, RecordSet or Connection objects.
  3. Recordset: A recordset is a group of records, and can either come from a base table or as the result of a query to the table. The RecordSet object contains a Fields collection and a Properties collection. The Fields collection is a set of Field objects, which are the corresponding columns in the table. The Properties collection is a set of Property objects, which defines a particular functionality of an OLE DB provider. The RecordSet has numerous methods and properties for examining the data that exists within it. Records can be updated in the recordset by changing the values in the record and then calling on the Update or UpdateBatch method. Adding new records is performed through the AddNew function and then by calling on the Update or UpdateBatch method. Records are also deleted in the recordset with the Delete method and then by calling on the Update method. However, if for some reason the deletion cannot occur, such as because of violations in referential integrity, then the recordset will remain in edit mode after the call to the Update method. The programmer must explicitly call on the CancelUpdate function to cancel the update. Additionally, ADO can roll back transactions (if this is supported) and cancel batch updates. Recordsets can also be updated in one of three ways: via an immediate update, via a batch update, or through the use of transactions:
    1. Immediate: The recordset is locked using the adLockOptimistic or adLockPessimistic lock. The data are updated at the data source after the record is changed and the Update method is called.
    2. Batch: The recordset is locked using adLockBatchOptimistic and each time Update is called the data are updated in a temporary buffer. Finally, when UpdateBatch is called the data are completely updated back at the data source. This has the advantage of it all being done in memory, and if a problem occurs then UpdateCancel is called and the updates are not sent to the data source
    3. Transaction: If the OLE DB provider allows it, transactions can be used. To start the transaction, the programmer invokes the BeginTrans method and does the required updates. When they are all done, the programmer invokes the CommitTrans method. RollbackTrans can be invoked to cancel any changes made inside the transaction and roll back the database to the state before the transaction began
  4. Record: This object represents one record in the database, and contains a fields collection. A RecordSet consists of a collection of Record objects.
  5. Stream: A stream, mainly used in a RecordSet object, is a means of reading and writing a stream of bytes. It is mostly used to save a recordset in an XML format, to send commands to an OLE DB provider as an alternative to the CommandText object and to contain the contents of a binary or text file.
  6. Parameter: A parameter is a means of altering the behaviour of a common piece of functionality, for instance a stored procedure might have different parameters passed to it depending on what needs to be done; these are called parameterised commands.
  7. Field: Each Record object contains many fields, and a RecordSet object has a corresponding Field object also. The RecordSet object's Field object corresponds to a column in the database table that it references.
  8. Property: This object is specific to the OLE DB provider and defines an ability that the provider has implemented. A property object can be either a built-in property – it is a well defined property implemented by ADO already and thus cannot be altered – or a dynamic property – defined by the underlying data provider and can be changed
  9. Error: When an OLE DB provider error occurs during the use of ADO, an Error object will be created in the Errors collection. Other errors do not go into an Error object, however. For instance, any errors that occur when manipulating data in a RecordSet or Field object are stored in a Status property.

ADO.NET

ADO.NET is the latest version of ADO (after ADO 2.8, now often referred to as ADO Classic) and is part of the MDAC 2.8 stack alongside classic ADO. It is built around Microsoft .NET. Though sometimes seen as an evolutionary step up from ADO, some fundamental structural changes were made by Microsoft. ADO.NET runs through a .NET Managed Provider, a modified version of an OLE DB provider specifically designed for .NET. The object structure is no longer built around a Recordset object. Instead a Dataset object is used to contain data gathered from multiple sources. This is transparent to the programmer. Unlike the old ADO Recordset, the Dataset's design promotes the use of disconnected data. Conceptually, a Dataset object can be seen as a small in-memory relational database in its own right that allows for manipulation of data in any direction. In order to propagate changes back into the database, a DataAdapter object is used that transfers data from between the data source and the DataSet object. Cursors were also deprecated in ADO.NET, being replaced with a DataReader object, which is used to efficiently process a large list of results one record at a time without storing them.

Deprecated and obsolete components

MDAC is a continually evolving component framework. As such, there have been several components that were previously part of it but have since been deprecated or removed entirely from the framework.

Jet Database Engine and JRO

See also: Access Database Engine

Jet stands for Joint Engine Technology and was a database engine used for Microsoft Access, Microsoft Exchange Server and Visual Basic. Jet was part of a Relational Database Management System (RDBMS) and offered a single interface that other software could use to access Microsoft databases. Jet also provided support for security, referential integrity, transaction processing, indexing, record and page locking, and data replication. In later versions of Jet, the engine was extended to run SQL queries, store character data in Unicode format, create views, and allowed bi-directional replication with the Microsoft SQL Server. It was superseded by MSDE which was superseded SQL Server Express.

There were three modules to Jet. One was the Native Jet ISAM Driver, a Jet dynamic link library (DLL) that could directly manipulate Microsoft Access database files (MDB), which was a modified form of an Indexed Sequential Access Method (ISAM) database. Another one of the modules were the ISAM Drivers, DLLs that allowed access to ISAM databases, among them being Xbase, Paradox, Btrieve and FoxPro files. The final module was the Data Access Objects (DAO) DLL, DAO allowed programmers access to the Jet engine. It was basically an object-oriented data language used by Access Basic and Visual Basic application developers to access Jet.

Similarly, the Microsoft Jet OLE DB Provider and Replication Objects (JRO) which allowed replication between Jet data sources was removed from MDAC 2.6

MSDASQL and Oracle ODBC

The Microsoft OLE DB Provider for ODBC, or MSDASQL, was an OLE DB provider for allowing ActiveX Data Objects access to databases via any ODBC driver. Microsoft supplied several OLE-DB providers (for the Indexing Service, Active Directory, Jet, SQL Server, Oracle (MSDAORA) and Internet Publishing), however unless otherwise directed, ADO defaulted to using MSDASQL as the default provider. After MDAC 2.5 both the Oracle ODBC driver and MSDASQL supported Oracle 7 and partially supported Oracle 8i. Features that were not supported were:

Microsoft initially deprecated the MSDASQL component for their 64-bit operating systems and the Microsoft Oracle ODBC driver was later superseded by a .NET Managed Oracle Provider, which supported Oracle 9i. However, Windows Server 2008 and Windows Vista SP1 ship with a 64-bit version of MSDASQL.

Remote Data Services (RDS)

Remote Data Services (RDS) allowed the retrieval of a set of data from the server, which the client then altered in some way and then sent back to the server for further processing. With the popular adoption of Transact-SQL, which extends SQL with such programming constructs as loops and conditional statements, this became less necessary and it was eventually deprecated in MDAC 2.7. Microsoft produced SOAP Toolkit 2.0, which allows clients to do this via an open XML-based standard.

SQLXML

SQLXML was designed for SQL Server 2000, but was deprecated with MDAC 2.6. It allowed Microsoft's relational database to be viewed by XPath and allowed data to viewable as an XML file. It has not actually been deprecated but has been removed from later versions of MDAC, though Microsoft does provide it as a downloadable component and will support it on their 64-bit operating systems.

Obsolete components

Several components have been completely removed from MDAC by Microsoft and are no longer supported. They are:

  • ESQL/C: Embedded SQL (also known as E-SQL or ESQL/C) is a way of using SQL when programming in Visual C. Microsoft dropped support for this after SQL Server 6.5 was released, though they did license some of the ESQL/C run-time environment to a company called Micro Focus, who develops COBOL compilers and tools
  • DAO: DAO, or Data Access Objects were an object oriented interface created by Microsoft which allowed early versions of Microsoft Access and Visual Basic to access the Jet Database Engine. Later (in version 3.5) it was able to bypass the Jet engine altogether and directly access ODBC data sources.
  • RDO: Remote Data Objects, or RDO, was a Microsoft technology that allowed for the creation of interfaces that directly called on ODBC. RDO version 2.0 was the final version developed by Microsoft.
  • DB-Library: a C-based API that allowed an application to interact with SQL Server. It will not be supported on any product after SQL Server 2000, and no features were added after SQL Server 6.5.

History

Microsoft has released several versions of MDAC over time. The distribution method has varied and the feature-set is different for each version.

MDAC 1.0

MDAC 1.0 was first released in August 1996. According to Microsoft, "MDAC 1.0 existed more as concept than a coordinated, stand-alone setup program." The MDAC 1.0 stack consisted of ODBC 3.0, OLE DB 1.1, ADO 1.0, and the Advanced Data Connector (ADC) 1.0 – which according to Microsoft was the precursor to the Remote Data Service of MDAC 1.5. It also included ODBC drivers for Access/Jet, SQL Server and Oracle databases. MDAC 1.0 was released via several mechanisms: the Advanced Data Connector shipped with Internet Information Server (IIS) 3.0 and as a downloadable cab file; OLE DB 1.1 and ADO 1.0 shipped with the OLE DB 1.1 SDK, which came with Visual Studio 97 and was also downloadable. MDAC 1.0 came with Active Server Pages, that itself came in IIS 3.0, and also came with Visual InterDev 1.0.

MDAC 1.5

MDAC 1.5 was released between September 1997 and March 1998, and involved a more centralised distribution mechanism than MDAC 1.0. It was released with Microsoft Internet Explorer 4.0, the Internet Client SDK 4.0 and through a CD-ROM given out at the 1997 Professional Developers Conference (PDC). There were five versions of MDAC 1.5:

  • MDAC 1.5 (initial release): included with Internet Explorer 4.0 and the Internet Client SDK.
  • MDAC 1.5a: downloadable from Microsoft's website
  • MDAC 1.5b: came with Windows NT 4.0 Option Pack & Office 97
  • MDAC 1.5c: fixed issues with ADO threading and ODBC Connection Pooling and was distributed via the Microsoft website. It only came with the ADO/MDAC runtime components.
  • MDAC 1.5d: came included with Windows 98 and Internet Explorer 4.01 service pack 1.

The different versions of MDAC 1.5 consisted of:

  • ODBC 3.5
  • OLE DB 1.5
  • ADO 1.5
  • Remote Data Service 1.5, which superseded the Advanced Data Connector.

This version of MDAC had a security flaw that made it vulnerable to an escalated privileges attack. The vulnerability caused systems that had both IIS and MDAC installed to give an unauthorized web user the ability to execute shell commands on the IIS system as a privileged user. This allowed the attacker to use MDAC to tunnel SQL and other ODBC data requests through the public connection to a private back-end network when on a multi-homed Internet-connected IIS system. It also allowed the user to gain unauthorized access to secured, non-published files on the IIS system

MDAC 1.5 was the last data access component release supported under Windows NT 3.51 SP5.

MDAC 2.0

MDAC 2.0 was distributed with the Data Access 2.0 SDK and included the contents of MDAC 1.5, the ODBC 3.5 SDK and the OLE DB 1.5 SDK, and the OLE DB for OLAP Specification. It also had included many updates to the core product, including a security feature added to the RDS which prevented it from being used maliciously an IIS server. This version came included in Windows NT 4.0 SP4, and also with Visual Studio 6.0, which came with the full Data Access SDK.

MDAC 2.1

MDAC 2.1 was distributed with SQL Server 7.0 and SQL Server 6.5 SP5. MDAC 2.1 SP1 was distributed with Internet Explorer 5 and MDAC 2.1 SP1a (GA) was distributed with Microsoft Office 2000, BackOffice 4.5 and Visual Studio 98 SP3. However, none of these versions of MDAC were released to the general public via the World Wide Web. MDAC 2.1 SP2 was distributed from Microsoft's website. The components that were included with 2.1 were:

  • ADO 2.1
  • RDS 2.1
  • OLE DB 2.1
  • the OLE DB Provider for ODBC, SQL Server and Oracle
  • JRO 2.1
  • a Jet driver
  • RDO.

This version had security vulnerabilities whereby an unchecked buffer could allow an elevated privileges attack. This was found some time later and it affected MDAC 2.1, 2.5 and 2.6 and was addressed in a later patch

MDAC 2.5

MDAC 2.5 was released on February 17, 2000, and distributed with Windows 2000, and the MDAC service packs were released in parallel with the Windows 2000 service packs. They were also distributed through Microsoft's website. Three service packs were released. The components included with 2.5 were:

  • ADO 2.5
  • ADO MD 2.5
  • ADOX 2.5
  • RDS 2.5
  • OLE DB 2.5
  • many OLE DB Providers
  • JRO 2.5
  • ODBC 3.51
  • many ODBC drivers
  • many Jet drivers.

Several issues were found in this version of MDAC. When using OLE DB Session Pooling, Microsoft COM+ would try to continuously load and unload OLE DB, and a conflict could arise that caused the OLE DB Session Pooling to run at 100% CPU usage. This was later fixed. Microsoft published a full list of bugs fixed in MDAC 2.5 Service Pack 2 and MDAC 2.5 Service Pack 3. A security vulnerability also existed (later fixed) whereby an unchecked buffer was found in the SQL Server Driver. This flaw was introduced in MDAC 2.5 SP2.

MDAC 2.6

MDAC 2.6 was released in September 2000 and was distributed through the web and with Microsoft SQL Server 2000 MDAC 2.6 RTM, SP1 (released June 20, 2001), and SP2 (released June 11, 2002) were distributed in parallel with the Microsoft SQL Server 2000 service packs, and could also be downloaded from the Microsoft website.

Beginning with this version of MDAC, Microsoft Jet, Microsoft Jet OLE DB Provider, and the ODBC Desktop Database Drivers were not included. Instead, these could be installed manually. Microsoft also released an alert warning that MDAC 2.6 should not be installed on an SQL Server 7.0 Cluster, because "if you install MDAC 2.6 or later on any node in the cluster, directly or through the installation of another program, it may cause a catastrophic failure of the SQL Server Agent or other SQL Server services." This issue affected Veritas Software's Backup Exec 9.0 for Windows Servers, because it installs Microsoft SQL Server 2000 Desktop Engine (MSDE 2000) as its database. Revision 4367 installed MDAC version 2.6 SP2 while revision 4454 installed MDAC version 2.7 SP1, which did not have the problem

MDAC 2.7

MDAC 2.7 was released in October 2001 through Microsoft's website. A refresh release was issued in April 2002 through the release of Windows XP and through Microsoft's website. Version 2.7 was available in U.S. English, Chinese (Traditional and Simplified), German, Japanese, Korean, Brazilian Portuguese, Czech, Danish, Greek, Slovak, Slovenian, Spanish, Finnish, French, Hungarian, Italian, Dutch, Norwegian, Polish, Portuguese, Russian, Swedish, and Turkish. Hebrew and Arabic were only available through Windows XP.

The main feature change was support for Microsoft's 64-bit operating system, however support for Banyan VINES was also dropped from this version of MDAC. There were several known issues: MDAC 2.7 continued causing connectivity problems on clustered servers running Microsoft SQL Server 6.5 or SQL Server 7.0, with no workaround provided by Microsoft. When creating or configuring ODBC data source names (DSNs) using the Microsoft SQL Server ODBC driver the network library protocol might unexpectedly switch to TCP/IP, even if the DSN was configured to use named pipes. This issue was found by InfoWorld reporter Randall C. Kennedy, who identified that the change was actually made in MDAC 2.6 but was never documented. It was discovered when testing client/server database workloads on a Windows XP computer; InfoWorld claims that although overall server CPU utilization rose by only 8 percent using TCP/IP, context switches per second dropped by more than 150 percent (which is of course impossible because you would then have a negative context switch rate - the drop is either 33% or 60% depending on which planet the author was on at the time of writing) for a 10-user workload. They were unimpressed that a fundamental functional change to the default behaviour of Net-Lib occurred without more than a passing mention in an unrelated document. Windows XP users also sometimes experienced problems connecting to SQL Server because SQL Server attempts to use certificates it finds on the local computer, however if there is more than one certificate available it did not know which one to use. When attempting to use Microsoft Analysis Services 2000 RTM, an error would sometimes appear when trying to browse cubes. Microsoft also discovered a problem in Windows 95, Windows 98, and Windows Me's setup program which prevented the MDAC installation program from rolling back when it encountered an installation error.

Several security issues were resolved by Microsoft for MDAC 2.7. David Litchfield of Next Generation Security Software Ltd reported a security vulnerability that results because one of the ODBC functions in MDAC that is used to connect to data sources contained an unchecked buffer. Another vulnerability that was fixed was one whereby an attacker could respond to an SQL Server discovery message broadcast by clients with a specially crafted packet that could cause a buffer overflow. Another flaw was found whereby code could be executed remotely when the attacker responded to the broadcast with another specially crafted packet.

MDAC 2.8

MDAC 2.8 was released in August 2003 and distributed with Microsoft Windows Server 2003, as well as on Microsoft's Data Access Technologies website. It did not introduce any new features to the product but fixed a number of bugs and security issues – a reg file (automates changes to the registry) was removed that made the server run in an "unsafe" mode whereby the RDS could be exploited to gain unauthorized access to the system and a new restriction was imposed on the length of the Shape query string. There were also several ODBC Administrator changes.

On May 23, 2005, Brad Rhodes (Lead Program Manager of Microsoft Data Access Technologies) announced that MDAC 2.8 SP1 was the last stand-alone redistributable of MDAC that Microsoft will ship. MDAC is now an official component of the Microsoft's operating system, though they will be providing ongoing bug and security fixes to previously released versions of the web-distributable version. However, Microsoft have created a new component called the SQL Native Client (SQLNCLI), which is a stand-alone data access API that has combined the OLE DB and ODBC libraries into one DLL. It was formed to be independent of MDAC, which is now reliant on the state the operating system is in – a developer now links to this library and avoids situations where an update of the operating system which updates MDAC breaks applications built to a different version of MDAC.

Windows 7 SP1 has broken forward compatibility of MDAC 2.8. Software compiled on Windows 7 SP1 that relies on MDAC ADO will not work on Windows versions prior to Windows 7 SP1 (including Windows 7 RTM, Vista, XP). Microsoft has provided solutions to work around this issue for some applications but VBA applications remain affected. The fix for this issue has been release in February 2012.

Windows DAC 6.0

Windows Vista will no longer use MDAC, but instead use Windows DAC, which consists of updated versions of ADO, OLE DB, and ODBC components. According to Microsoft, "Windows DAC includes some changes to work with Windows Vista, but is almost entirely functionally equivalent to MDAC 2.8."

Version checking

There are two ways of checking the version of MDAC that is installed on a computer. For Windows 2000, Windows XP and Windows Server 2003, one way to check is via Microsoft's Component Checker program, which compares the value of each installed MDAC DLL to the MDAC file manifest. The second way is to check the key HKEY_LOCAL_MACHINE\Software\Microsoft\DataAccess\FullInstallVer in the Windows registry. Microsoft notes that this information may be incorrect for versions of MDAC prior to 2.1 when compared with the versions of the MDAC files installed to the system

Version Release date Included with Features Security issues
1.0 August 1996
  • ADC – IIS 3.0
  • OLE DB 1.1 SDK (OLE DB 1.1 and ADO 1.0) – Visual Studio
  • All components included in Visual Interdev 1.0 and with Active Server Pages (released in IIS 3.0)
  • ODBC 3.0
  • OLE DB 1.1
  • ADO 1.0
  • ADC 1.0
  • ODBC drivers for Access/Jet, SQL Server and Oracle databases

No bulletins released

1.5

September 1997 – March 1998
  • Microsoft Internet Explorer 4.0
  • Internet Client SDK 4.0 (from CD issued at Microsoft PDC)
  • ODBC 3.5
  • OLE DB 1.5
  • ADO 1.5
  • RDS 1.5 (superseded ADC 1.0)
1.5a September 1997–March 1998

Service release

1.5b September 1997–March 1998

Service release

1.5c September 1997–March 1998
  • Fixed issues with ADO threading and ODBC Connection Pooling
  • Only came with ADO/MDAC runtime components
2.0 July 1, 1998
  • Visual Studio 98
  • Data Access 2.0 SDK
  • ODBC 3.5 SDK
  • OLE DB 1.5 SDK
  • OLE DB for OLAP Specification
2.0SP1 July 1, 1998
  • Windows NT 4.0 SP4

Y2K remediation for Windows NT 4.0

2.0SP2 July 1, 1998
  • Microsoft website

Y2K remediation for all platforms

2.1 July 11, 1998
  • SQL Server 7.0
  • SQL Server 6.5 SP5
  • ADO 2.1
  • RDS 2.1
  • OLE DB 2.1
  • OLE DB Provider for ODBC, SQL Server and Oracle
  • JRO 2.1
  • ODBC driver
  • Jet driver
  • RDO
2.1 SP1 March 15, 1999
  • Internet Explorer 5.0
  • Windows 98 Second Edition
2.1 SP1a (GA) April 1, 1999
  • Office 2000
  • BackOffice 4.5
  • Visual Studio 98 SP3
  • Internet Explorer 5.0a (minimal install)
2.1 SP2 July 1999
2.5 February 17, 2000
  • Windows 2000
  • ADO 2.5
  • ADO MD 2.5
  • ADOX 2.5
  • RDS 2.5
  • OLE DB 2.5
  • OLE DB Provider for the ODBC driver for:
    • SQL
    • Server
    • Site Server Search
    • Internet Publishing
    • Jet 4.0 (Access 2000)
    • Oracle
    • Indexing Services (Index Server)
    • Microsoft Data Shaping Services
    • OLAP Services
    • DTS Packages
    • Microsoft Directory Services
    • Server DTS Flat File
    • OLE DB Simple Provider
  • JRO 2.5
  • ODBC 3.51
  • an ODBC driver for
    • Microsoft Access
    • SQL Server
    • Microsoft Excel
    • Text
    • Visual FoxPro
    • FoxPro VFP
    • dBase
    • dBase VFP
    • Paradox
    • Oracle
  • Jet drivers for:
    • Excel
    • Microsoft Exchange
    • Access
    • text files
    • Lotus 1-2-3
    • Paradox
    • xBase
2.5 SP1 July 31, 2000
  • Windows 2000 SP1
2.5 SP2 April 2000
  • Windows 2000 SP2
2.5 SPS3 December 2003
  • Windows 2000 SP3
2.6 September 2000
  • SQL Server 2000
Not included (manually installed):
  • Microsoft Jet
  • Microsoft Jet OLE DB Provider
  • ODBC Desktop Database Drivers
2.6 SP1 May 2001
  • SQL Server 2000 SP1
2.6 SP2 May 2002
  • SQL Server 2000 SP2
2.7 October 2001
  • Windows XP
  • Support for 64-bit operating systems
  • Banyan VINES support dropped
2.8 August 2003
  • Windows Server 2003

Fixed bugs and security issues

2.8 SP1 May 2005
  • SQL Server 2000 SP4
  • Windows XP SP2

Fixed bugs

2.8 SP2 March 2005
  • Windows Server 2003 SP1
9.0 Never released
  • Visual Studio 2005 Beta 1 (Removed in subsequent releases)
  • SQL Server 2005 Beta 1 (Removed in subsequent releases)
Windows DAC 6.0 (a variant of MDAC for use with Vista) November 2006
  • Version number synchronized with Windows version
  • No other new features

References

  1. Kalen Delaney, "Inside Microsoft SQL Server 2000", Microsoft Press, pp. 70–74.
  2. MSDN, "Creating a udl file", "ADO 2.8 API Reference", accessed April 28, 2007.
  3. ibid.
  4. Prash Shirolkar (Author); Alyssa Henry (contributor); Stephen Pepitone (Contributor); Acey J. Bunch (contributor); David Schwartz (contributor), "Data Access Technologies Road Map", Microsoft Corporation, accessed March 1, 2018.
  5. MSDN, "Fields Collection", "ADO 2.8 API Reference", accessed September 19, 2005.
  6. MSDN, "Properties Collection", "ADO 2.8 API Reference", accessed September 19, 2005.
  7. MSDN, "Parameters Collection", "ADO 2.8 API Reference", accessed September 19, 2005.
  8. MSDN, "Errors Collection", "ADO 2.8 API Reference", accessed September 19, 2005.
  9. MSDN, "Using a connection object", "ADO 2.8 Programmers Guide", accessed September 10, 2005.
  10. MSDN, "ADO Connection String", "ADO 2.8 Programmers Guide", accessed September 10, 2005.
  11. MSDN, "Command Object Overview", "ADO 2.8 Programmers Guide", accessed September 10, 2005
  12. MSDN, "Examining Data", "ADO 2.8 Programmers Guide", accessed September 10, 2005.
  13. A full list of ADO methods and properties that allow the examination of data in a recordset can be found in Microsoft's API documentation
  14. MSDN, "Editing data", "ADO 2.8 Programmers Guide", accessed September 10, 2005.
  15. MSDN, "Deleting records using the Delete method", "ADO 2.8 Programmers Guide", accessed September 10, 2005.
  16. MSDN, "Updating and Persisting Data", "ADO 2.8 Programmers Guide", accessed September 12, 2005.
  17. MSDN, "Transaction Processing", "ADO 2.8 Programmers Guide", accessed September 12, 2005.
  18. MSDN, "Record Object", "ADO 2.8 API Reference", accessed September 12, 2005.
  19. MSDN, "Records and Streams", "ADO 2.8 Programmers Guide", accessed September 12, 2005.
  20. MSDN, "Streams and Persistence", "ADO 2.8 Programmers Guide", accessed September 12, 2005.
  21. MSDN, "Parameter Object", "ADO 2.8 API Reference", accessed September 12, 2005.
  22. MSDN, "Field Object", "ADO 2.8 API Reference", accessed September 12, 2005.
  23. MSDN, "Property Object" "ADO 2.8 Programmers Guide", accessed September 13, 2005.
  24. MSDN, "Error Handling", "ADO 2.8 Programmers Guide", accessed September 18, 2005.
  25. MSDN, "Field-Related Error Information", "ADO 2.8 Programmers Guide", accessed September 18, 2005; & MSDN, "Recordset-Related Error Information", "ADO 2.8 Programmers Guide", accessed September 18, 2005.
  26. Doug Rothaus & Mike Pizzo, "ADO.NET for the ADO Programmer", MSDN, accessed September 22, 2005.
  27. Microsoft, Deprecated Components (OLE DB), retrieved August 5, 2005.
  28. Hamilton, Bill (2008). ADO.NET 3.5 Cookbook. Cookbook Series (2 ed.). O'Reilly Media, Inc. p. 27. ISBN 9780596101404. Retrieved 2012-10-09. use the Oracle OLE DB provider (MSDAORA) to access Oracle data.
  29. Microsoft, "Data Access Technologies Road Map", Deprecated MDAC Components, Microsoft "ADO Programmer's Guide" Appendix A: Providers, Microsoft OLE DB Provider for ODBC Archived 2001-10-05 at the Wayback Machine, retrieved July 30, 2005.
  30. Microsoft, MS KB article 244661: INFO: Limitations of Microsoft Oracle ODBC Driver and OLEDB Provider, last reviewed August 25, 2004, retrieved August 4, 2005.
  31. Microsoft, "Remote Data Service (RDS)", retrieved August 11, 2005.
  32. Microsoft, "Data Access Technologies Roadmap", "Deprecated MDAC Components"
  33. Kalen Delaney, "Inside Microsoft SQL Server 2000", Microsoft Press, p65.
  34. Christine Solomon, "Microsoft Office 97 Developer's Handbook", Microsoft Press. pp. 195–200.
  35. (in German) Christian Koller, "ADO und MDAC Versionen" : MDAC 1.0 and 1.1 (OLE DB 1.0 and OLE DB 1.1) accessed July 1, 2005.
  36. ^ INFO: What are MDAC, DA SDK, ODBC, OLE DB, ADO, RDS, and ADO/MD?, Microsoft, March 14, 2005, retrieved 2005-07-01
  37. ^ Koller, Christian, "ADO und MDAC Versionen", MDAC 1.5 (in German), retrieved 2005-07-01
  38. Microsoft, Microsoft Security Program: Frequently Asked Questions: Microsoft Security Bulletin (MS99-025), accessed July 6, 2005.
  39. Microsoft, PRB: RDS Handler Error Messages Due to Security Settings (last reviewed September 30, 2003), accessed July 6, 2005; Microsoft Security Program: Microsoft Security Bulletin (MS98-004) : "Unauthorized ODBC Data Access with RDS and IIS" (last revision: July 17, 1998), accessed July 6, 2005; CVE vulnerability CVE-1999-1011.
  40. Christian Koller, "ADO und MDAC Versionen" : MDAC 2.0, accessed July 1, 2005.
  41. (in German) Christian Koller, "ADO und MDAC Versionen" : MDAC 2.1, accessed July 1, 2005.
  42. Microsoft, "Data Access Components: Security Hotfix for Q329414"; Microsoft Security Bulletin MS02-06 – originally Microsoft KB article Q329414) – (originally posted November 20, 2002), accessed July 6, 2005.
  43. (in German) Christian Koller, "ADO und MDAC Versionen" : MDAC 2.5, accessed July 1, 2005.
  44. Microsoft, MS KB article 320700, "OLE DB Session Pooling Causes 100 Percent CPU Usage (MDAC 2.5)", accessed July 6, 2005.
  45. Microsoft, MS KB article 842272 Release manifest for MDAC 2.6 (2.60.6526.3), accessed July 6, 2005.
  46. Microsoft, MS KB article 271908 MDAC version 2.6 and later do not contain Jet or Desktop ODBC drivers, accessed July 6, 2005.
  47. Microsoft, MS KB article 820754 MDAC 2.6 or later should not be installed on SQL Server 7.0 clusters, accessed July 6, 2005.
  48. Veritas, Document ID: 258144 VERITAS Backup Exec (tm) 9.0 for Windows Servers should not be installed on a Microsoft SQL Server 7.0 Cluster. Archived 2013-01-05 at archive.today
  49. "Release manifest for MDAC 2.7 Refresh (2.70.9001.0)". Support.microsoft.com. Retrieved 2019-04-10.
  50. Microsoft, MS KB article 289573 PRB: Configuring DSNs with SQL Server Net-Libraries.
  51. Kennedy, Randall C. (21 November 2001). "It's not a bug, it's a feature". InfoWorld. IDG. Archived from the original on 10 March 2007.
  52. Microsoft, MS KB article 309398 SQL Server 2000 installation or local connections fail with "SSL Security error:ConnectionOpen (SECDoClientHandshake())" error message.
  53. Microsoft, MS KB article 297232 FIX: Cannot Browse Cubes or Process Mining Model After You Install Analysis Services 2000 RTM.
  54. Microsoft, MS KB article 311720 PRB: MDAC Rollback May Fail on Windows 95, Windows 98, and Windows Millennium Edition.
  55. Microsoft, Microsoft Security Bulletin MS02-040 Unchecked Buffer in MDAC Function Could Enable System Compromise (Q326573).
  56. Microsoft, Microsoft Security Bulletin MS03-033 Unchecked Buffer in MDAC Function Could Enable System Compromise (823718)
  57. Microsoft, Microsoft Security Bulletin MS04-003 Buffer Overrun in MDAC Function Could Allow Code Execution (832483)
  58. Microsoft. MS KB article 818490: INFO: Handunsf.reg File Has Been Removed in MDAC 2.8 Redist Setup for Security Reasons
  59. Microsoft. MS KB article 838405: FIX: "Argument passed to data shaping service was invalid" error after you apply MDAC 2.8
  60. Microsoft. MS KB article 818489, INFO: ODBC Administrator Changes in MDAC 2.8.
  61. Brad Rhodes (blog entry), The end of the MDAC Redistributable, May 23, 2005, retrieved August 11, 2005; & Microsoft, MS KB article 892854: "Release strategy for Microsoft Data Access Components", last updated January 24, 2005, retrieved August 11, 2005.
  62. Acey J. Bunch (April 26, 2005), "Introducing SQL Native Client", MSDN blog entry.
  63. MSDN, "Breaking change in MDAC ADODB COM components in Windows 7 Service Pack 1", "Forum", accessed March 9, 2011.
  64. KB 2517589, "An ADO application that is re-compiled on a Windows 7 Service Pack 1-based computer does not run on down-level operating systems", "", accessed March 17, 2011.
  65. KB 2640696, "An ADO-based application that is compiled in Windows 7 SP1 or in Windows Server 2008 R2 SP1 does not run in earlier versions of Windows", "", accessed April 20, 2012.
  66. Microsoft, "FAQ About Windows DAC/MDAC". Accessed 12th December, 2006.
  67. Microsoft. MS KB article 301202, How to check for MDAC version, last updated January 18, 2005, retrieved September 29, 2005.
  68. Chapter 11 Changes, supplementary material to "A First Look at SQL Server 2005 for Developers" by Bob Beauchemin, Niels Berglund, and Dan Sullivan. Archived March 24, 2006, at the Wayback Machine

Further reading

External links

Microsoft APIs and frameworks
Graphics and UI
Audio
Multimedia
Web
Data access
Networking
Communication
Administration and
management
Component model
Libraries
Device drivers
Security
.NET
Software factories
IPC
Accessibility
Text and multilingual
support
Category:
Microsoft Data Access Components: Difference between revisions Add topic