ado oracle数据库,C++ 通过ADO连接Oracle数据库-程序员宅基地

技术标签: ado oracle数据库  

背景接触C++以来,因为之前学的java做Web时经常要和数据库打交道,所以也就一直想用C++来操作数据库。之前也听过ODBC数据源的方法听说比较麻烦,C++用ADO的方法

背景

接触C++以来,因为之前学的java做Web时经常要和数据库打交道,所以也就一直想用C++来操作数据库。之前也听过ODBC数据源的方法听说比较麻烦,C++用ADO的方法连接数据比较方便。

下面就是具体的步骤和代码了。

1.导入ADO的库

使用ADO的话必须要导入它的库,这语句放到头文件.h中,因为我这里是用的MFC程序建的工程,所以我放在stdafx.h头文件中

//导入ADO的库

#import "C:\\Program Files\\Common Files\\System\\ado\\msado15.dll" no_namespace rename("EOF","adoEOF")文件msado15.dll可以在你的电脑中的相应路径C:\Program Files\Common Files\System\ado找到;no_namespace 表示没有命名空间,可以不写不过后面的ADO对象要加上ADODB::引入;rename("EOF","adoEOF")是用adoEOF替换EOF ,如果你用到BOF的话也可以通过这种方式替换。

2.在头文件中定义成员变量和成员函数

在AdoDlg.h文件中:

//定义变量

_ConnectionPtr m_conn; //连接智能指针

_RecordsetPtr m_rec;//记录集智能指针

HRESULT hr;

// //列表控件变量

CListCtrl m_listCtrl;

//函数

bool AdoOpen(char* userName,char* pwd,char* conStr,char* errStr); //连接数据库

//_RecordsetPtr AdoExucute(char* sqlStr); //执行sql语句,,操作表

bool AdoClose();//关闭数据库

void InsertCol();//插入表头

void GetRecordSet();//获得记录集

void AdoQuery();//查询数据

bool AdoAdd();//增加数据

bool AdoUpdate();//修改数据

bool AdoDelete();//删除数据

3.在使用ADO前要初始化COM类库环境

在AdoDlg.cpp文件中:

a.在构造函数中初始化成员变量

m_conn=NULL;

b.在OnInitDialog()函数中

//初始化COM类库

//CoInitialize返回的是HRESULT类型的值,返回S_OK(值为0)表示COM初始化成功,

// 返回S_FALSE(值为1)表示当前线程已经初始化过COM,所以返回S_OK或S_FALSE都是对的

/*if(FAILED(::CoInitialize(NULL)))

{

MessageBox("初始化COM库失败");

return FALSE;

}*/

AfxOleInit();//MFC工程建议用AfxOleInit();//控制台建议用CoInitalize(),同时在Close函数或是析构函数中记得调用::CoUninitialize();卸载COM环境;

//MFC工程建议用AfxOleInit();就行了。

4.实现成员函数

a .建立与数据库的连接

//连接数据库

bool CAdoDBDlg:: AdoOpen(char* userName,char* pwd,char* conStr,char* errStr)

{

//捕获异常

try{

//创建Connection对象的一个实例

hr=m_conn.CreateInstance(_uuidof(Connection));///创建Connection对象

//通过用户名、密码以及连接字符串连接数据库

m_conn->Open(conStr,userName,pwd,NULL);

}catch(_com_error e)

{

MessageBox(e.ErrorMessage());

}

return TRUE;

}

b.获得查询的结果集

//获取结果集

void CAdoDBDlg::GetRecordSet()

{

CString sql= "select * from MEMBERUSER"; //查询的SQL语句

try{

m_rec.CreateInstance(_uuidof(Recordset));//创建结果集对象

m_rec->Open(_bstr_t(sql),m_conn.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);

}catch(_com_error e)

{

MessageBox(e.Description());

}

}aa. ADO中Recordset.Open()参数说明

bb.ADO中数据类型的介绍variant、BSTR

C.也可通过Execute函数来获得结果集

//执行SQL语句

_RecordsetPtr CAdoDBDlg::AdoExucute(char* sqlStr)

{

try

{

if(m_conn==NULL)

{

MessageBox("请先连接数据库,再操作!");

return NULL;

}

_variant_t RecordsAffected;//此次操作的记录数

_RecordsetPtr PRecord;

//通过sql语句操作数据库并返回结果集指针

PRecord=m_conn->Execute(_bstr_t(sqlStr),&RecordsAffected,adCmdText);

/*int IntRecords = RecordsAffected.intVal;

CString StrRecords="0";

StrRecords.Format("此次操作了 %d 条数据.",IntRecords);

AfxMessageBox(StrRecords);*/

return PRecord;

}

catch (_com_error e)

{

MessageBox(e.ErrorMessage());

}

}

D.关闭函数

//关闭数据库连接

bool CAdoDBDlg::AdoClose()

{

if(m_conn!=NULL)

{

m_conn->Close();//关闭连接

m_conn=NULL;

m_rec->Close();//关闭结果集

m_rec=NULL;

//::CoUninitialize();//卸载COM环境

}

if(m_conn==NULL)

return TRUE;

else

return FALSE;

}

E.插入列表控件的表头和设置样式

我用的是CListCtrl控件来显示查询到的数据,因为之前做类似Windows任务管理器时就是用的列表控件来显示数据,所以第一就想到了用它来显示表中的数据。

//插入表头

void CAdoDBDlg::InsertCol()

{//表的列名

CString szItem[]={("记录数"),_T("ID"),_T("MemberName"),_T("AccounterNumber"),_T("Age"),_T("Gender"),_T("Birthday"),_T("RoleName"),_T("Pwd"),_T("Integal")};

//设置列表控件的样式

LONG lStyle;

lStyle= GetWindowLong(m_listCtrl.m_hWnd,GWL_STYLE);//获得列表控件的当前样式

lStyle &=~LVS_TYPEMASK; //清除显示方式位

lStyle |=LVS_REPORT; //设置view属性的值为Report

SetWindowLong(m_listCtrl.m_hWnd,GWL_STYLE,lStyle);

//设置扩展风格--网格

m_listCtrl.SetExtendedStyle(LVS_EX_GRIDLINES|LVS_EX_FULLROWSELECT);

//设置列表控件的表头

int szLength = sizeof(szItem)/sizeof(szItem[0]);//求出数组长度

for (int i=0;i

{

m_listCtrl.InsertColumn(i,szItem[i],LVCFMT_RIGHT,70,-1);//向控件中插入表头

}

}aa.遍历数据库中的所有表名和表的所有字段 第 6.7点

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_28958485/article/details/116344424

智能推荐

vue 海康视频播放_vue-hkvideo-程序员宅基地

文章浏览阅读4k次,点赞4次,收藏22次。1. 下载并安装海康 web 插件https://open.hikvision.com/download/5c67f1e2f05948198c909700?type=102. 把上一步解压的三个 js, 复制到你的项目中, 根据路径, 自己引入到 index.html 中3. 建议运行它的 demo, 大概看看代码, 了解一下它的大致结构, 它的注解很详细, 3 分钟就能看完4. 贴上我的代码(我的是每次只显示一个画面, 点击摄像头切换画面)<temp.._vue-hkvideo

html li 鼠标经过变色,CSS实现li标签鼠标经过时改变背景颜色-程序员宅基地

文章浏览阅读5.3k次,点赞3次,收藏4次。很多时候需要用到这个css效果,实际上就用了一个li标签的热点样式,不仅是li标签,div等也可以的完整代码如下,div/css鼠标热点改变li标签背景颜色body{ background-color:#CCCC99; margin:0; padding:0; color:#fff;}ul{ margin:0; padding:50px;}li{ list-style:none; height:2..._ul li 样式 鼠标移入颜色

数据恢复:在 Linux 上恢复删除了的文件_linux系统,删了某一个文件夹的数据还清空了回收站,还能不能找回来我的数据-程序员宅基地

文章浏览阅读238次,点赞4次,收藏8次。把删除创建为rm -i 的别名当 -i 选项配合 rm 命令(也包括其他文件处理命令比如 cp 或者 mv)使用时,在删除文件前会出现一个提示。其中,/home/gacanepa/rescued 是另外一个磁盘中的目录 - 请记住,把文件恢复到被删除文件所在的磁盘中不是一个明智的做法。安装完成后,我们做一个简单的测试吧。如果在恢复过程中,占用了被删除文件之前所在的磁盘分区,就可能无法恢复文件。但愿你对于你的文件足够小心,当你要从外部磁盘或 USB 设备中恢复丢失的文件时,你只需使用这个工具即可。

2021-09-15 WPF上位机 15-属性绑定(数据格式化)_wpf 自定义属性绑定 格式化 实现-程序员宅基地

文章浏览阅读3.2w次。<Window x:Class="Zhaoxi.BindingStudy.DataFormatStudy.DataFormatStudyWin" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.._wpf 自定义属性绑定 格式化 实现

[常用办公软件] wps怎么自动生成目录?wps自动生成目录的设置教程_wps目录自动生成-程序员宅基地

文章浏览阅读1.1w次,点赞3次,收藏5次。转载请说明来源于"厦门SEO"本文地址:http://www.96096.cc/Article/160880.html常用办公软件  WPS Office是由金山软件股份有限公司开发的一款针对个人永久免费的办公软件,在我们的日常生活和工作中,WPS Office比起微软Microsoft Office来说在文字上的处理会更深入国人用户的人心,熟悉操作WPS的办公小技巧,能够更高效的提高我们的工作效率,今天小编要为大家分享的是WPS怎么自动生成目录?快来一起看看WPS自动生成目录的设置教程吧。_wps目录自动生成

web项目-程序员宅基地

文章浏览阅读7.4k次,点赞2次,收藏19次。web项目是指服务端部署在服务器上,客户端使用浏览器通过网络传输进行访问获取数据的项目。通常我们看见的应用页面网站等等都可以称之为web项目。 在web项目的开发中可分为web前端开发和web后端开发 web前端:即是客户端能看得见碰得着得东西。包括Web页面结构、页面样式外观以及Web层面得交互展现。 前端特点:页面视觉效果良好(客户第一)、Web页面交互流畅(..._web项目

随便推点

RecyclerView实现吸顶效果项目实战(三):布局管理器LayoutManager-程序员宅基地

文章浏览阅读338次,点赞4次,收藏6次。架构师不是天生的,是在项目中磨练起来的,所以,我们学了技术就需要结合项目进行实战训练,那么在Android里面最常用的架构无外乎 MVC,MVP,MVVM,但是这些思想如果和模块化,层次化,组件化混和在一起,那就不是一件那么简单的事了,我们需要一个真正身经百战的架构师才能讲解透彻其中蕴含的深理。此时,RecyclerView第一个item是添加进Adapter中的最后一个,最后一个item是第一个加进Adapter的数据,RecyclerView会自动滑到末尾,另外item整体是依靠下方的。

【智能排班系统】基于AOP和自定义注解实现接口幂等性-程序员宅基地

文章浏览阅读884次。使用多种方式实现接口幂等性,通过定义注解方便对方法进行幂等性控制

SpringBoot整合Swagger2 详解_springboot swagger2 开关-程序员宅基地

文章浏览阅读324次。SpringBoot、Swagger2 整合详解_springboot swagger2 开关

spring boot 项目报错 java.sql.SQLException: The server time zone value '�й���׼ʱ��' is unrecognized_springboot项目里面报错 the server time zone value ' й-程序员宅基地

文章浏览阅读2.8w次,点赞96次,收藏115次。报错说是时区不对因为mysql-connection-java版本导致时区的问题。pom.xml:控制台报错信息:java.sql.SQLException: The server time zone value ‘�й���׼ʱ��’ is unrecognized or represents more than one time zone. You must configure ei..._springboot项目里面报错 the server time zone value ' й

最全Android Kotlin 学习路线(Kotlin 从入门、进阶到实战)_kotlin学习-程序员宅基地

文章浏览阅读4.2k次。Kotlin 是由 jetBrains 开发的一门现代多平台应用的静态编程语言,Kotlin 代码即可以编译成 Java 字节码,又可以编译成 JavaScript,Kotlin 是开源的,源码在这。Kotlin 包含了大量的语法糖,在编码的时候,会大大的简化我们的代码量及工作效率。且相比传统的 Java 语言,Kotlin 种大量的简写,可以减少很多用Java 必须要写的样板代码,减少大量的 if…else 等嵌套,减少大量接口的实现,代码结构也会更加清晰。_kotlin学习

【前端素材】推荐优质新鲜绿色蔬菜商城网站设计Harmic平台模板(附源码)-程序员宅基地

文章浏览阅读753次,点赞30次,收藏21次。在线绿色新鲜果蔬商店网站是指一个专门销售新鲜、绿色、有机水果和蔬菜的电子商务平台。这类网站旨在为消费者提供方便、快捷的购买渠道,同时确保他们能够购买到高质量、新鲜的产品。