- 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
Executing Commands
You can execute simple commands by using the Execute() method of the ADOConnection object, whose prototype is shown here:
HRESULT Execute(
BSTR CommandText,
VARIANT *RecordsAffected,
long Options,
ADORecordset *pSet);
The text of the command, which is generally an SQL command, is passed in the CommandText parameter. You can also pass the address of a VARIANT in RecordsAffected. Upon completion, the long value in the VARIANT at RecordsAffected contains the number of rows that were affected by the command. In addition to SQL commands, you can pass a table name or stored procedure in CommandText. The Options parameter is used to specify the type of command that is passed in CommandText. Options can be passed one of the following values:
- adCmdText—CommandText is a text (usually SQL) command.
- adCmdTable—CommandText is a table name.
- adCmdStoredProc—CommandText is a stored procedure.
For commands that generate a result set, Execute() stores a pointer to a recordset containing the results of the command in the pSet parameter. You can use this recordset to retrieve the results of the command.
The following executeSQL function shows how to execute a simple command using the Execute() method of the ADOConnection object:
CComPtr<ADORecordset> executeSQL(BSTR SQL) {
//Execute function written by Chuck Wood
//Executes SQL and returns any recordset that's formed
CComPtr<ADORecordset> pSet;
VARIANT recAffected;
m_pConn->Execute(SQL, &recAffected, adCmdText, &pSet);
return pSet;
}
Transactions | Next Section

Account Sign In
View your cart