VC6下ADO数据库编程(1)--动态创建数据库文件
2014-01-16 18:46
489 查看
使用ADO前必须在工程的stdafx.h文件最后用直接引入符号#import引入ADO库文件,以使编译器能正确编译。代码如下:
#import "c:\program files\common files\system\ado\msadox.dll" rename("EOF","adoxEOF")
#import "C:\Program Files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")
ADO类的定义是作为一种资源存储在ADO DLL(msado15.dll)中,在其内部称为类型库。类型库描述了自治接口,以及C++使用的COM vtable接口。当使用#import指令时,在运行时Visual C++需要从ADO DLL中读取这个类型库,并以此创建一组C++头文件。这些头文件具有.tli 和.tlh扩展名,读者可以在项目的目录下找到这两个文件。在C++程序代码中调用的ADO类要在这些文件中定义。
程序的第三列指示ADO对象不使用名称空间。在有些应用程序中,由于应用程序中的对象与ADO中的对象之间可能会出现命名冲突,所以有必要使用名称空间。如果要使用名称空间,则可把第三行程序修改为: rename_namespace("AdoNS")。第四行代码将ADO中的EOF(文件结束)更名为adoEOF,以避免与定义了自己的EOF的其他库冲突。
msadox.dll创建数据库
msado15.dll操作数据库
msjro.dll压缩修复数据库
动态创建数据库示例代码:
#import "c:\program files\common files\system\ado\msadox.dll" rename("EOF","adoxEOF")
#import "C:\Program Files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")
ADO类的定义是作为一种资源存储在ADO DLL(msado15.dll)中,在其内部称为类型库。类型库描述了自治接口,以及C++使用的COM vtable接口。当使用#import指令时,在运行时Visual C++需要从ADO DLL中读取这个类型库,并以此创建一组C++头文件。这些头文件具有.tli 和.tlh扩展名,读者可以在项目的目录下找到这两个文件。在C++程序代码中调用的ADO类要在这些文件中定义。
程序的第三列指示ADO对象不使用名称空间。在有些应用程序中,由于应用程序中的对象与ADO中的对象之间可能会出现命名冲突,所以有必要使用名称空间。如果要使用名称空间,则可把第三行程序修改为: rename_namespace("AdoNS")。第四行代码将ADO中的EOF(文件结束)更名为adoEOF,以避免与定义了自己的EOF的其他库冲突。
msadox.dll创建数据库
msado15.dll操作数据库
msjro.dll压缩修复数据库
动态创建数据库示例代码:
/** * 动态创建数据库文件 * 示例(创建access2000数据库文件): * const LPCWSTR DATABASE_SOURCE = L"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=G:\\myDatabase.mdb"; * const LPCWSTR SQL_CREATE_TABLE= L"create table TimeRecording(RecordingDate Date,Duration Long,Comments Text)"; * CreateMDB(DATABASE_SOURCE, SQL_CREATE_TABLE); * * @param databaseSource 数据源 * @param sqlCreateTable 创建数据表的语句 * @return 创建成功返回true,否则false */ BOOL CAccessDatabaseDlg::CreateMDB(LPCWSTR databaseSource, LPCWSTR sqlCreateTable) { ::CoInitialize(NULL); HRESULT hr = S_OK; _ConnectionPtr pConnection; try { ADOX::_CatalogPtr pCatalog = NULL; hr = pCatalog.CreateInstance(__uuidof (ADOX::Catalog)); if(FAILED(hr)) { _com_issue_error(hr); } else { pCatalog->Create(_bstr_t(databaseSource)); //Create mdb } //Create table pConnection.CreateInstance(__uuidof(Connection)); pConnection->Open(_bstr_t(databaseSource), "", "", adConnectUnspecified); _variant_t RecordsAffected; CString strSql; BSTR bstrSQL; strSql = _T(sqlCreateTable); bstrSQL = strSql.AllocSysString(); pConnection->Execute(bstrSQL, &RecordsAffected, adCmdText); } catch(_com_error &e) { AfxMessageBox(e.ErrorMessage()); pConnection = NULL; ::CoUninitialize(); return FALSE; } pConnection->Close(); pConnection = NULL; ::CoUninitialize(); return TRUE; }
相关文章推荐
- Hibernate动态建表,通过hbm.xml配置文件创建数据表,进行数据库操作, 动态模型
- Hibernate动态建表,通过hbm.xml配置文件创建数据表,进行数据库操作, 动态模型
- ADO创建数据库文件(*.MDB)
- 如何使用 ADO.NET 和 Visual C# .NET 以编程方式创建 SQL Server 数据库
- 在VB程序中用ADO对象动态创建数据库和表
- 动态创建服务器控件,获取HTML输出(用于生成静态文件,简化页面,简化编程等)
- 动态创建服务器控件,获取HTML输出(用于生成静态文件,简化页面,简化编程等)
- 动态创建服务器控件,获取HTML输出(用于生成静态文件,简化页面,简化编程等)
- 如何使用 ADO.NET 和 Visual C++ .NET 以编程方式创建 SQL Server 数据库
- VB中用ADO对象动态创建数据库和表
- java JDBC编程——从属性文件读取信息,并创建到数据库的连接
- VB程序中用ADO对象动态创建数据库和表
- ADO.NET数据库编程 利用应用程序配置文件进行数据的读取
- 在Web应用中动态创建PDF文件-Java基础-Java-编程开发
- 创建Accress 数据库连接文件UDL/如何使用 ADO 的数据链接文件
- 使用ADO.NET和C#以编程方式创建 SQL Server 数据库
- 在VB6中动态创建使用ADO控件访问数据库
- VB程序中用ADO对象动态创建数据库和表
- VC6下ADO数据库编程(2)--增、改、查
- ADO.NET数据库编程