- Table of Contents
- Copyright
- About the Authors
- About the Contributors
- Acknowledgments
- Tell Us What You Think!
- Introduction
- How to Use This Book
- What You Need to Use This Book
- What's New in Visual C++ 6.0
- Contacting the Main Author
- Part I: Introduction
- Chapter 1. The Visual C++ 6.0 Environment
- Part II: MFC Programming
- Chapter 2. MFC Class Library Overview
- Chapter 3. MFC Message Handling Mechanism
- Chapter 4. The Document View Architecture
- Chapter 5. Creating and Using Dialog Boxes
- Chapter 6. Working with Device Contexts and GDI Objects
- Chapter 7. Creating and Using Property Sheets
- Chapter 8. Working with the File System
- Chapter 9. Using Serialization with File and Archive Objects
- Part III: Internet Programming with MFC
- Chapter 10. MFC and the Internet Server API (ISAPI)
- Chapter 11. The WinInet API
- Chapter 12. MFC HTML Support
- Part IV: Advanced Programming Topics
- Chapter 13. Using the Standard C++ Library
- Chapter 14. Error Detection and Exception Handling Techniques
- Chapter 15. Debugging and Profiling Strategies
- Chapter 16. Multithreading
- Chapter 17. Using Scripting and Other Tools to Automate the Visual C++ IDE
- Part V: Database Programming
- Chapter 18. Creating Custom AppWizards
- Chapter 19. Database Overview
- Chapter 20. ODBC Programming
- Chapter 21. MFC Database Classes
- Chapter 22. Using OLE DB
- Chapter 23. Programming with ADO
- ADO Objects
- Connection Objects
- ADOCommand Objects
- ADORecordset Objects
- ADOFields Collections and ADOField Objects
- ADOParameter Objects and the ADOParameters Collection
- ADOProperty Objects and ADOProperties Collections
- Writing a Visual C++ ADO Application
- Processing ADO Errors
- Enhanced ADO Recordset Functionality
- Executing Commands
- Transactions
- Summary
- Part VI: MFC Support for COM and ActiveX
- Chapter 24. Overview of COM and Active Technologies
- Chapter 25. Active Documents
- Chapter 26. Active Containers
- Chapter 27. Active Servers
- Chapter 28. ActiveX Controls
- Part VII: Using the Active Template Library
- Chapter 29. ATL Architecture
- Chapter 30. Creating COM Objects Using ATL
- Chapter 31. Creating ActiveX Controls Using ATL
- Chapter 32. Using ATL to Create MTS and COM+ Components
- Part VIII: Finishing Touches
- Chapter 33. Adding Windows Help
- Part IX: Appendix
Connection Objects
ADO uses Connection objects to represent an individual connection to an OLE DB datasource. Of course, if you are also using MSDASQL, this OLE DB datasource might also correspond to an ODBC datasource.
Any operation performed on a datasource requires a Connection object, although you don't necessarily need to create it yourself. In many cases, you can simply let ADO create a connection used by command or recordset objects. However, you can also perform many operations by using just the Connection object, such as executing SQL that updates database tables. Connection objects are also used to create a single connection that is used by several other objects, which can be useful for optimizing your application. Connection objects are also used to manage transactions in ADO.
To declare a Connection instance, use Visual C++'s smart CComPTR pointer and the CoCreateInstance() function:
//ADO header files Added by Chuck Wood for ADO support
#include <adoid.h>
#include <adoint.h>
#include <comdef.h>
//...
CcomPtr<ADOConnection> m_pConn;
//...
CoCreateInstance(CLSID_CADOConnection, NULL,
CLSCTX_INPROC_SERVER, IID_IADOConnection,
(LPVOID *) &m_pConn);
After creating a Connection variable, you can connect to the database using the ADOConnection.Open() method:
m_pConn->Open((CComBSTR) "VCUnleashed",
(CComBSTR) "",
(CComBSTR) "",
adOpenUnspecified));
ADOConnection Properties
All ADO Connection objects have the following properties, although specific implementations offer additional properties:
- Attributes is used to describe certain characteristics of the connection.
- CommandTimeout contains the timeout value to be used for executing commands. This value is also used for other command objects using this connection, although the command objects can override this value by setting their own command timeout.
- ConnectionString contains information that is used to connect to the data source. This can include the provider, datasource, user, password, or filename of the datasource.
- ConnectionTimeout is the timeout value that is used when attempting to establish a connection.
- DefaultDatabase is the default database, or catalog, that is used within the datasource.
- IsolationLevel is the isolation level that is used with transactions on this connection.
- Mode indicates the read/write and sharing permissions for the connection.
- Provider is used to specify the provider that will be used. This defaults to MSDASQL, which is the ODBC provider.
- Version specifies the version of the ADO implementation.
Connection objects also contain a Properties collection, which is used to work with certain characteristics of the connection, and an ADOErrors collection, which contains information about any errors or warnings generated by an operation on the connection.
ADOConnection Methods
All ADO connections also support the following methods, although additional methods might also be provided:
- Open is used to open a connection to a datasource.
- Close is used to close a datasource connection and its dependent objects.
- Execute executes a command against the connected datasource. In most cases, this is an SQL query.
- BeginTrans begins a transaction on the connection.
- CommitTrans commits the current transaction.
- RollbackTrans rolls back any changes made in the current transaction.
ADOCommand Objects | Next Section

Account Sign In
View your cart