vc下动态创建access数据库的实现

2016-02-19 21:06 59 1 收藏

下面是个超简单的vc下动态创建access数据库的实现教程,图老师小编精心挑选推荐,大家行行好,多给几个赞吧,小编吐血跪求~

【 tulaoshi.com - 编程语言 】

本文描述如何在VC下动态创建access数据库(mdb)文件,方法是用ADO和ADOX来操作数据库,操作环境为winxp/VC6.0/ACCESS2000。具体方法如下。    

   使用ADO前必须在工程的stdafx.h文件最后用直接引入符号#import引入ADO库文件,以使编译器能正确编译。代码如下:

#import "C:Program Filescommon filessystemadomsado15.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的其他库冲突。 这里直接引用一程序当中的一个函数作为例子来说明。

BOOL CConvertmdbDlg::Createmdb()
{
 WIN32_FIND_DATA fd;
 HANDLE hFind = FindFirstFile(m_mdbpath, &fd);
 if (hFind != INVALID_HANDLE_VALUE)
  return TRUE;
 
 ::CoInitialize(NULL);
 HRESULT hr = S_OK;
 
 try
 {
  ADOX::_CatalogPtr pCatalog = NULL;
  hr = pCatalog.CreateInstance(__uuidof (ADOX::Catalog));
 
  if(FAILED(hr))
  {
   _com_issue_error(hr);
  }
  else
  {
   pCatalog-Create(_bstr_t(m_strconn)); //Create mdb
  }
  //Create table
  m_pConn.CreateInstance(__uuidof(Connection));
  m_pConn-Open(_bstr_t(m_strconn), "", "", adConnectUnspecified);
 
  _variant_t   RecordsAffected;
  CString strSql;
  BSTR bstrSQL;
 
  strSql = _T("CREATE TABLE AXISSave(ID INTEGER,X_Axis REAL,
   Y_Axis REAL,TestResult INTEGER)");
  bstrSQL = strSql.AllocSysString();
  m_pConn-Execute(bstrSQL, &RecordsAffected, adCmdText);
 }
 catch(_com_error &e) 
 {
  AfxMessageBox(e.ErrorMessage());

  m_pConn = NULL;
  ::CoUninitialize();
  return FALSE;
 }
 
 m_pConn-Close();

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

 m_pConn = NULL;
 ::CoUninitialize();
 
 return TRUE;
}

看如下语句 

ADOX::_CatalogPtr pCatalog = NULL;
  hr = pCatalog.CreateInstance(__uuidof (ADOX::Catalog));
 
  if(FAILED(hr))
  {
   _com_issue_error(hr);
  }
  else
  {
   pCatalog-Create(_bstr_t(m_strconn)); //Create mdb
  }

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

上面就是动态创建mdb文件的语句,其中m_strconn为如下格式的字符串,比如:

pCatalog-Create(_bstr_t("Provider=Microsoft.JET.OLEDB.4.0;Data source=C:test.mdb"));

将在C盘跟目录下创建一个test.mdb文件

  strSql = _T("CREATE TABLE AXISSave(ID INTEGER,X_Axis REAL,
   Y_Axis REAL,TestResult INTEGER)");
  bstrSQL = strSql.AllocSysString();
  m_pConn-Execute(bstrSQL, &RecordsAffected, adCmdText);

上面语句就是动态创建test.mdb数据库中表的核心语句,它是利用Connection对象的Execute方法来执行SQL命令

上面例子创建一个名为AXISSave,字段分别为ID,X_Axis,Y_Axis,TestResult的表,注意不能创建字段index

创建之后就可以利用ADO库三个智能指针:_ConnectionPtr、_CommandPtr和_RecordsetPtr进行数据库的操作

来源:https://www.tulaoshi.com/n/20160219/1625289.html

延伸阅读
一、密码式 给数据库起一个随机复杂的名称,避免被猜到被下载,这种方式在以前很流行,因为大家都对自己的代码很有自信。但随着错误提示对数据库地址的泄露导致数据库被非法下载,这种方式也就越来越少人用了。 二、"#"式 在数据库名称里加上#号,从URL上请求时#是请求地址和请求参数的一个分隔字符,如果知道了数据库名...
问:我们单位财务以前用的Access是97版,前不久将Access 97升级至2000版本了。升级完成后出现问题,打开原有的文件后系统提示:“Access 2000无法识别旧版本的数据库文件”,请问有没有办法可以修复数据库? 答:你可以利用软件AccessFix(下载地址为http://www.onlinedown.net/soft/16220.htm)来修复数据库。安装完成后点击按钮“Add ...
适用:ACCESS2000 ACCESS97 数据库规格是MDB的工作极限,以下列出ACCESS2000的规格,与ACCESS97只有极少差异,有差异者皆特别注明。 ●数据库 数据库档案大小 : 20亿字节(ACCESS97为10亿字节) 一个数据库内的组件数目: 32,768 模快 : 1024 一个组件名称的字节数 : 64 一个密码的字节数 : 14 ...
准备: (1)、引入ADO类 #import "c:program filescommon filessystemadomsado15.dll" no_namespace rename ("EOF", "adoEOF") (2)、初始化COM 在MFC中可以用AfxOleInit();非MFC环境中用: CoInitialize(NULL); CoUnInitialize(); (3)#import 包含后就可以用3个智能指针了:_ConnectionPtr、_RecordsetPtr和_CommandPtr 1.连接和关闭数据...
摘要:MySQL数据库作为一种网络数据库性能十分出色,但其在应用软件中使用较少。本文将主要探讨MySQL提供的两种数据库接口 ——(ODBC API和C API)在VC中的应用,并且形成一个类用以封装C API数据库接口的功能。 关键词:MySQL;数据库接口;ODBC API;C API 3 利用MySQL自带的C API函数实现数据库功能调用 由于各个数据库之间的差异,...

经验教程

544

收藏

99
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部