Microsoft Visual C++(VC)是一种非常流行的编程语言,用于开发Windows应用程序。在VC中,通过打开数据库,可以轻松地与数据交互,包括从数据库中检索数据,对数据进行添加、删除和修改等操作。本文将介绍,帮助您轻松实现数据交互。
一、准备工作
在使用VC打开Access数据库之前,您需要做一些准备工作。您需要有一个Access数据库。如果您还没有Access数据库,可以借助Microsoft Office套件创建一份。您需要安装OLEDB和ODBC驱动程序,以确保VC能够与数据库进行交互。您需要安装Microsoft Visual C++,我们将在此以VC2023为例。
二、打开Access数据库
1.新建VC项目
我们需要在VC2023中创建一个新项目。在“文件”菜单下选择“新建项目”,选择“Win32控制台应用程序”,并在下个界面选择“空项目”。
2.包含头文件
在VC2023中,我们需要包含头文件“#include ”和“#include ”,以使VC能够调用定义了与Oledb相关的类型和函数。您可以将这些头文件添加到您的源代码文件中。
3.创建连接
我们需要创建一个指向Access数据库的连接,以便访问其中的数据。使用以下代码创建连接:
CoInitialize(NULL);
IDBInitialize *pDbInitialize = NULL;
CoCreateInstance(CLSID_OLEDB_CONVERSIONLIBRARY, NULL, CLSCTX_INPROC_SERVER, IID_IDBInitialize, (void**)&pDbInitialize);
DBPROP rgProperty[2];
memset(rgProperty, 0, sizeof(rgProperty));
ULONG cProperty = 2;
VARIANT varDataDictionary, varPassword;
VariantInit(&varPassword);
rgProperty[0].dwPropertyID = DBPROP_INIT_DATASOURCE;
rgProperty[0].dwOptions = DBPROPOPTIONS_REQUIRED;
rgProperty[0].vValue.vt = VT_BSTR;
rgProperty[0].vValue.bstrVal = SysAllocString(L”C:\\mydb.mdb”);
rgProperty[1].dwPropertyID = DBPROP_AUTH_PASSWORD;
rgProperty[1].dwOptions = DBPROPOPTIONS_REQUIRED;
rgProperty[1].vValue.vt = VT_BSTR;
rgProperty[1].vValue.bstrVal = SysAllocString(L”mypassword”);
pDbInitialize->SetProperties(cProperty, rgProperty);
DBPROPSET rgPropSet[1];
rgPropSet[0].cProperties = 1;
rgPropSet[0].rgProperties = rgProperty;
rgPropSet[0].guidPropertySet = DBPROPSET_DBINIT;
DBPROPSET *prgPropSets[1];
prgPropSets[0] = rgPropSet;
HRESULT hr = pDbInitialize->Initialize();
if (SUCCEEDED(hr))
{
qDebug()
}
else
{
qDebug()
}
4.访问数据库
现在,我们已经创建了指向Access数据库的连接,下一个步骤是访问数据库中的数据。使用以下代码检索数据库中的数据:
IDBCreateSession *pDbCreateSession = NULL;
pDbInitialize->QueryInterface(IID_IDBCreateSession, (void**)&pDbCreateSession);
IDBSession *pDbSession = NULL;
pDbCreateSession->CreateSession(NULL, IID_IDBSession, (IUnknown**)&pDbSession);
IBindCtx *pBindCtx = NULL;
CreateBindCtx(0, &pBindCtx);
IMalloc *pMalloc = NULL;
CoGetMalloc(1, &pMalloc);
ULONG cchEaten = 0;
LPMONIKER pmkObjectName = NULL;
hr = MkParseDisplayName(pBindCtx, L”Data Source=C:\\mydb.mdb”, &cchEaten, &pmkObjectName);
if (SUCCEEDED(hr))
{
BindMoniker(pmkObjectName, 0, IID_IDBCreateCommand, (void**)&pDbCreateCommand);
}
IUnknown *pUnkOuter = NULL;
HRESULT hr = pDbSession->CreateSession(pUnkOuter, IID_IOpenRowset, (IUnknown**)&pOpenRowset);
if (SUCCEEDED(hr))
{
hr = pOpenRowset->OpenRowset(NULL, L”CoCreateTable”, NULL, IID_IRowset, 0, NULL, NULL, (IUnknown**)&pRowset);
}
5.关闭连接
完成对数据库的操作后,我们需要在VC中关闭连接,释放资源。使用以下代码关闭连接:
if (pRowset != NULL)
{
pRowset->Release();
}
if (pDbSession != NULL)
{
pDbSession->Release();
}
if (pOpenRowset != NULL)
{
pOpenRowset->Release();
}
三、
相关问题拓展阅读:
- VC6.0,ADO访问Access2023数据库的问题
- 请问数据库ACCESS和SQL用什么软件编写,运行
- 几种VC++数据库开发技术的比较
VC6.0,ADO访问Access2023数据库的问题
你连接字符串叫user ID和password全为空?
加过这个语句了吗?AfxOleInit();
数据库操作容易出错,更好余耐梁加上try catch ,也竖运亩亩容易捕获错误
请问数据库ACCESS和SQL用什么软件编写,运行
一、主体不同
1、ACCESS数据库:是由微软发布的关系数据库管理系统。结合了Database Engine 和 图形用户界面两项特点。
2、SQL:指微软的SQLServer数据库服务器,是一个数据库平台,提供数据告逗库的从服务器到终端的完整的解决方案。
二、特点不同
1、袜羡卖ACCESS数据库:以自己的格式将数据存储在基于Aess Jet的数据库引擎里。它还可以直接导入或者链接数据。
2、SQL:为关系型数据和结构化数据提供了更安全可靠的存储功能,可以构建和管理用于业务的高可用和高性能的数据应用派扮程序。
三、优势不同
1、ACCESS数据库:会使用一个联合处理器来处理浮点型算术,整型数算术也总是要快一些。当你的计算不含有小数,尽量使用整型或长整型而不是变量或双整型。
2、SQL:达到了支持超大型企业进行联机事务处理 (OLTP)、高度复杂的数据分析、数据仓库系统和网站所需的性能水平。
几种VC++数据库开发技术的比较
从功能简单的数据库(如Jet Engine)到复杂的大型数据库系统(如oracle),VC++6.0都提供了一些编程接口。本文主要介绍以下五种:
1.ODBC API;
2.MFC ODBC类;
3.MFC DAO类;(数据访问对象)
4.MFC的OLE/DB;
5.ActiveX数据对象(ADO)。
1.开放数据库连接(ODBC API):提供了一个通用的编程接口,允许程序与多种不同的数据库连接。它为Oracle,SQL Server,MS Excel等都提供了驱动程序,使得用户可以使用SQL语句对数据库进行直接的底层功能操作。在使用ODBC API时,用户须引入的头文件为”sql.h”,”sqlext.h”,”sqltypes.h”。用ODBC API创建数据库应用程序遵循一定的基本步骤:
之一步是分配ODBC环境,使一些内部结构初始化。完成这一步,须分配一个SQLHENV类型的变量在ODBC环境中做句柄使用。
第二步是为将要使用的每一个数据源分源察晌配一个连接句柄,由函数SQLALLocHandle()完成。
第三步是使用SQLConnect()把连接句柄与数据库连接,可以先通过SQLSetConnectAttr()设置连接属性。
然后就可以进行SQL语句的操作,限于篇幅,相关的函数就不具体介绍了,读者可以参考相关书籍。
操作完成后,用户取回相应的结果,就可以取消与数据库的连接。
最后需要释放ODBC环境。
ODBC API的特点是功能强大丰富,提供了异步操作,事务处理等高级功能,但相应的编程复杂,工作量大。
2.MFC ODBC类:MFC1.5后的版本里引入封装了ODBC功能的类。通过这些类提供与ODBC的接口,使得用户可以不须处理ODBC API中的繁杂处理就可以进行数据库操作。主要的MFC ODBC类如下。
CDatabase类:一个CDatabase对象表示一个到数据源的连接,通过它可以操作数据源。应用程序可使用多个CDatabase对象:构造一个对象并调用OpenEx()成员函数打开一个连接。接着构造CRecordSet对象以操作连接的数据源,并向CDatabase对象传递记录集构造程序指针。完成使用后用Close()成员函数销毁CDatabase对象。一般情况下并不需要直接使用CDatabase对象,因为CRecordSet对象可以实现大多数的功能。但是在进行事务处理时,CDatabase就起到关键作用。事务(Transaction)指的是将一系列对数据源的更新放在一起,同时提交或一个也不提交,为的是确保多用户对数据源同时操作时的数据正确性。
CRecordSet类:一个CRecordSet对象代表一个从数据源选择的一组记录的-记录集。记录集有两种形式:snapshot和dynaset。前者表示数据的静态视图,后者表示记录集与其他用户对数据库的更新保持同步。通过CRecordSet对象,用户可以对数据库中的记录进行各种操作。
CRecordView类:CRecordView对象是在空间中显示数据库记录的视图。这种视图是一种直接连到一个CRecordSet对象的格式视图,它从一个对话框模板资源创建,并将CRecordSet对象没举的字段显示在对话框模板的控件里。对象利用DDX和RFX机制,使格式上的控件和记录集的字段之间数据移动自动化,也就是说,用户甚至不要编写一行代码就可雹锋以实现简单的数据库记录查看程序。
CDBException类:由Cexception类派生,以三个继承的成员变量反映对数据库操作时的异常:
m_nRetCode:以ODBC返回代码(SQL_RETURN)的形式表明造成异常的原因。
m_strError:字符串,描述造成抛出异常的错误原因。
m_strStateNativeOrigin:字符串,用以描述以ODBC错误代码表示的异常错误。
MFC数据库类成员函数都能抛出CDBException类型的异常,所以在代码对数据库进行操作后监测异常是正确做法。
MFC ODBC类在实际开发中应用最广,因为它功能丰富,操作相对简便。
3.MFC DAO(数据访问对象)编程:DAO用于和微软的Access数据库接口。在数据库应用程序如果只需与Access数据库接口时,使用DAO编程较方便。其主要类如下。
CDaoWorkspace:CDaoWorkspace对象可以让一个用户管理从登陆到离开期间,指定的密码保护的数据库会话全过程。大多数情况下不要多个工作区也不要创建明确的工作区对象。因为在打开数据库和记录集对象时,它们可以使用DAO缺省工作区。
CDaoDatabase:代表一个连接,类似上述CDatabase类。
CDaoRecordSet:用来选择记录集并操作,类似上述CRecordSet类。
CDaoRecordView:类似上述CRecordView类。
CDaoException:类似上述CDBException类。
CDaoTableDef:表示基本表或附加表的定义。每个DAO数据库对象包括一个称为TableDef的收集,包含所有存储的DAO表定义对象。CDaoTableDef对象可以用来控制表定义。
CDaoQueryDef:CDaoQueryDef对象表示了一个查询定义(querydef)。
CDaoFieldExchange:支持数据库类使用的DAO字段交换(DFX)例程。也可处理事务,类似MFC ODBC类。
MFC DAO仅用来支持Access数据库,应用范围相对固定。
4.OLE DB:OLE DB在数据提供程序和用户之间提供了灵活的组件对象模型(COM)接口,这种灵活性有时会使得操作复杂化。OLE DB框架定义了应用的三个基本类。
数据提供程序Data Provider:拥有自己的数据并以表格形式显示数据的应用程序。提供OLE DB的行集COM接口,期显示范围可以从单一数据表格的简单提供者知道更复杂的分布式数据库系统。
使用者Consumers:使用OLE DB接口对存储在数据提供程序中的数据进行控制的应用程序。用户应用程序归为使用类。
服务提供程序Service Provider:是数据提供程序和使用者的组合。服务提供程序没有自己的数据,但使用
OLE DB使用者接口来访问存储在数据提供程序中的数据。然后,服务提供程序通过打开数据提供程序接口使得数据对使用者有效。服务提供程序常用于向应用程序提供高层次服务,比如高级分布式查询。
OLE DB编程时,用户使用组件对象开发应用程序。这些组件有:
枚举器:用于列出可用的数据源;
数据源:代表单独的数据和服务提供程序,用于创建对话;
对话:用于创建事务和命令;
事务:用于将多个操作归并为单一事务处理;
命令:用于向数据源发送文本命令(SQL),返回行集;
错误:用于获得错误信息。
5.ActiveX数据对象(ADO):是微软提供的面向对象的接口,与OLE DB类似,但接口更简单,具有更广泛的特征数组和更高程度的灵活性。ADO基于COM,提供编程语言可利用的对象,除了面向VC++,还提供面向其他各种开发工具的应用,如VB,VJ等。ADO在服务器应用方面非常有用,特别是对于动态服务器页面ASP(Active Server Page)。
ADO对象结构类似于OLE DB,但并不依靠对象层次。大多数情况下,用户只需要创建并只使用需要处理的对象。下面的对象类组成了ADO接口。
Connection:用于表示与数据库的连接,以及处理一些命令和事务。
Command:用于处理传送给数据源的命令。
Recordset:用于处理数据的表格集,包括获取和修改数据。
Field:用于表示记录集中的列信息,包括列值和其他信息。
Parameter:用于对传送给数据源的命令之间来回传送数据。
Property:用与操作在ADO中使用的其他对象的详细属性。
Error:用于获得可能发生的错误的详细信息。
在VC++使用ADO需要进行COM操作,详细方法在此就不赘述了。
在当今流行的分布式开发环境下,VC++6.0在数据库开发方面有较强的优势,学会
在不同的场合选用不同的技术,对开发人员来说是必要的技术。
access数据库 vc open的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于access数据库 vc open,使用VC打开Access数据库的方法,VC6.0,ADO访问Access2023数据库的问题,请问数据库ACCESS和SQL用什么软件编写,运行,几种VC++数据库开发技术的比较的信息别忘了在本站进行查找喔。