C++ 连接Oracle
下面是一个ADO方式连接Oracle的小程序部分代码......
首先是Oracle的配置、在Oracle的安装路径下找到:Oracle\network\ADMIN\tnsnames.ora文件、配置一下连接配置
- BOSS =
- (DESCRIPTION =
- (ADDRESS_LIST =
- (ADDRESS = (PROTOCOL = TCP)(HOST = xx.xx.xx.xx)(PORT = 1521))
- )
- (CONNECT_DATA =
- (SERVICE_NAME = boss)
- )
- )
新建一个头文件、名为CDBOperation.h:
- #pragma once
- #import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename("EOF", "adoEOF")
- class CDBOperation
- {
- public:
- //初始化数据库操作需要的对象
- CDBOperation(void);
- ~CDBOperation(void);
- //连接至数据库
- bool ConnToDB(char *ConnectionString, char *UserID, char *Password);
- //数据库操作函数
- //查询操作 删除以及添加
- _RecordsetPtr ExecuteWithResSQL(const char *);
- private:
- void PrintErrorInfo(_com_error &);
- private:
- //初始化数据库连接、命令、记录集
- _ConnectionPtr CreateConnPtr();
- _CommandPtr CreateCommPtr();
- _RecordsetPtr CreateRecsetPtr();
- private:
- //数据库连接需要的连接、命令操作对象
- _ConnectionPtr m_pConnection;
- _CommandPtr m_pCommand;
- };
新建一个c++源文件、名为CDBOperation.cpp:
- #include "stdafx.h"
- #include "DBOperation.h"
- CDBOperation::CDBOperation(void)
- {
- CoInitialize(NULL);
- m_pConnection = CreateConnPtr();
- m_pCommand = CreateCommPtr();
- }
- CDBOperation::~CDBOperation(void)
- {
- m_pConnection->Close();
- }
- bool CDBOperation::ConnToDB(char *ConnectionString, char *UserID, char *Password)
- {
- if (NULL == m_pConnection)
- {
- printf("Failed to create connection\n");
- return false;
- }
- try
- {
- HRESULT hr = m_pConnection->Open(ConnectionString, UserID, Password, NULL);
- if (TRUE == FAILED(hr))
- {
- return false;
- }
- m_pCommand->ActiveConnection = m_pConnection;
- return true;
- }
- catch(_com_error &e)
- {
- PrintErrorInfo(e);
- return false;
- }
- }
- _RecordsetPtr CDBOperation::ExecuteWithResSQL(const char *sql)
- {
- try
- {
- m_pCommand->CommandText = _bstr_t(sql);
- _RecordsetPtr pRst = m_pCommand->Execute(NULL, NULL, adCmdText);
- return pRst;
- }
- catch(_com_error &e)
- {
- PrintErrorInfo(e);
- return NULL;
- }
- }
- void CDBOperation::PrintErrorInfo(_com_error &e)
- {
- printf("Error infomation are as follows\n");
- printf("ErrorNo: %d\nError Message:%s\nError Source:%s\nError Description:%s\n", e.Error(), e.ErrorMessage(), (LPCTSTR)e.Source(), (LPCTSTR)e.Description());
- }
- _ConnectionPtr CDBOperation::CreateConnPtr()
- {
- HRESULT hr;
- _ConnectionPtr connPtr;
- hr = connPtr.CreateInstance(__uuidof(Connection));
- if (FAILED(hr) == TRUE)
- {
- return NULL;
- }
- return connPtr;
- }
- _CommandPtr CDBOperation::CreateCommPtr()
- {
- HRESULT hr;
- _CommandPtr commPtr;
- hr = commPtr.CreateInstance(__uuidof(Command));
- if (FAILED(hr) == TRUE)
- {
- return NULL;
- }
- return commPtr;
- }
- _RecordsetPtr CDBOperation::CreateRecsetPtr()
- {
- HRESULT hr;
- _RecordsetPtr recsetPtr;
- hr = recsetPtr.CreateInstance(__uuidof(Command));
- if (FAILED(hr) ==TRUE)
- {
- return NULL;
- }
- return recsetPtr;
- }
我的代码是放在MFC一个按钮Click事件里面的:
记住在处理事件的cpp文件中导入头文件:#include "DBOperation.h"
- CDBOperation dbOper;
- bool bConn = dbOper.ConnToDB("Provider=OraOLEDB.Oracle.1;Persist Security Info=True;Data Source=boss", "用户名", "密码");
- if (false == bConn)
- {
- MessageBox((LPCTSTR)"连接数据库出现错误\0",0,0);
- return;
- }
- //查询
- _RecordsetPtr pRst;
- char sql[255] = {0};
- strcpy(sql, " select * from boss_test_table2 where rownum = 1 ");
- pRst = dbOper.ExecuteWithResSQL(sql);
- if (NULL == pRst)
- {
- MessageBox(_T("查询数据出现错误!\0"),0,0);
- return;
- }
- if (pRst->adoEOF)
- {
- pRst->Close();
- MessageBox((LPCTSTR)"There is no records in this table\0",0,0);
- return;
- }
- _variant_t vSno, vName;
- while (!pRst->adoEOF)
- {
- //pRst->MoveFirst(); //记录集指针移动到查询结果集的前面
- vSno = pRst->GetCollect(_variant_t("U_NUMBER"));
- vName = pRst->GetCollect(_variant_t("USERS_NAME"));
- MessageBox((LPCTSTR)(_bstr_t)vSno,0,0);
- pRst->MoveNext();
- }
- strcpy(sql, "insert into boss_test_table2 (u_number, users_name, users_phone, status, customno_id) values ('0001', 'C+TTT+', '13999000000', 2, 'BPPPPPPPPPP')");
- pRst = dbOper.ExecuteWithResSQL(sql);
- if (NULL != pRst)
- {
- AfxMessageBox(_T("插入数据成功\n"));
- }
- //执行删除语句
- sprintf(sql, "delete boss_test_table2 where u_number = '%s'", "009");
- pRst = dbOper.ExecuteWithResSQL(sql);
- if (NULL != pRst)
- {
- MessageBox(_T("删除数据成功\0"),0,0);
- }
- //执行更新语句
- sprintf(sql, "update boss_test_table2 set users_name = '%s' ", "C++反人类、MFC反社会");
- pRst = dbOper.ExecuteWithResSQL(sql);
- if (NULL != pRst)
- {
- MessageBox(_T("更新数据成功\0"),0,0);
- }
C++ 连接Oracle的更多相关文章
- 一起学微软Power BI系列-使用技巧(1)连接Oracle与Mysql数据库
说起Oracle数据库,以前没用过Oracle不知道,但是这1年用Oracle后,发现真的是想狂吐槽,特别是那个.NET驱动和链接字符串,特别奇葩.总归是和其他数据库不一样,标新立异,不知道为何.另外 ...
- Linux下部署ASP.NET服务连接oracle遇到的问题记录
一.如何卸载MONO Q:mono是linux系统上跨平台软件,卸载它有两种方式: 1.知道mono安装路径,安装原来的路径直接覆盖安装(最为简单): 2.不知道mono安装路径,首先通过sudo f ...
- Java JDBC Thin Driver 连接 Oracle 三种方法说明(转载)
一.JDBC 连接Oracle 说明 JDBC 的应用连接Oracle 遇到问题,错误如下: ORA-12505,TNS:listener does not currently know of SID ...
- 关于ADO.NET连接ORACLE,使用ODAC连接中的一些问题
ADO.NET连接ORACLE时,用到ODAC组件时,有几点注意的. 1.安装的具体方法见:http://jingyan.baidu.com/article/e4511cf336ce872b845ea ...
- Qgis连接Oracle
CMake编译中选择编译Oracle一项以后,编译的qgis才会有连接Oracle数据库的功能. 编译qgis以后,可以通过添加矢量图层中选择Oracle数据库,或是添加Oracle空间图层,或是添加 ...
- IIS 连接 oracle报Oracle.DataAccess版本错误解决办法
通过IIS连接oracle时报“Could not load file or assembly 'Oracle.DataAccess, Version=2.112.3.0, Culture=neutr ...
- 使用Navicat连接Oracle数据时的一些问题,连接时错误:ORA-28547,新建用户后连接时错误:ORA-01017
发现Navicat作为一款连接数据库的工具确实很好用,可视化的界面看着舒服很多,下面说说我今天在连接Oracle数据库时的一些问题: 1.安装好Oracle后直接用Navicat是连接不上的,会出现如 ...
- mac版本navicat连接oracle报错ORA-21561
最近电脑更换成mac,很多软件都和win不一样了,正在慢慢适应,连接oracle原来用的客户端是pl/sql develop,蛋疼的是没有了mac版本, 用了navicat,具体设置如下 1.新建连接 ...
- Java连接Oracle database小结
利用jdbc连接Oracle数据库,首先得选对jdbc的版本. jdk6需要ojdbc6.jar这个包.如果选错的话,调用isValid()这个方法时,有可能有这个异常: Exception in t ...
- 不安装oracle客户端,用plsql连接oracle
常用的Oracle开发的工具有SQL Developer和PL/SQL Developer,个人感觉前者虽然跨平台性优于后者,但比较大(大于300M)占用资源,而且用户体验也一般,而后者相对就小很多( ...
随机推荐
- python: 面向对象:类和对象调用类中的变量和方法
一. 面向对象初识 我们在生活中做事都是面向过程的,前面实现一些基本逻辑功能代码也是用面向过程的语句实现的,后来学了函数,把这些功能又装到了函数里.但用面向过程的方法去写程序,只能实现一个功能,我们要 ...
- String MVC @RequestParam(required=false) int XXX 参数为空报错解决方法
今天在用@RequestParam(required=false) int XXX 取参数的时候,当参数没有的时候Spring默认赋值为空.而此时使用基本类型int,所以报错,建议使用包装类 Inte ...
- [UE4]使用UnrealVS扩展快速编译C++代码
一.如果UE4 编辑器已经打开,则VS中的重新生成项目将不能使用,一定要关了UE4 编辑器才可以.一般不是有VS自身的编译UE4的C++代码 二.epic提供了UnrealVS扩展,可以快速编译C++ ...
- [UE4]场景截图
要点: 一.鼠标在编辑器关卡中点一下,然后按F9键截图,右下角会出现截图后的文件链接,点击后会自动打开截图文件所在的文件夹.截图的大小正好的关卡视图的大小. 编辑器:F9键截图,只截图关卡视图界面 运 ...
- 使用fakeroot模拟root权限执行程序(转)
Hack #57: 使用fakeroot模拟root权限执行程序 fakeroot是什么 例如Debian在生成package的时候,编译完之后,不能立刻在当前环境执行make install,需要执 ...
- remmina从linux远程桌面连接windows失败解决方法
删除如下文件,重新连接 rm ~/.freerdp/known_hosts
- centos 7 安装sqoop 1.4.7
1. 下载sqoop1.4.7 cd /home/workspace wget https://mirrors.tuna.tsinghua.edu.cn/apache/sqoop/1.4.7/sqoo ...
- C#语言基础知识
一. string i_str = "321"; string 型,强制转换成 int 型 int i_int1 = int.parse(i_str); string 型,强制转换 ...
- 基于拖放布局的 Twitter Bootstrap 网站生成器
简单的几个拖放操作就能做出漂亮的 Twitter Bootstrap 网站?是的,LayoutIt 是一个 Twitter Bootstrap 界面生成器,能够帮助你快速制作出网站和界面模型,同时能够 ...
- Centos7基于容器安装运行Docker私有仓库及添加认证
一.前言 官方的Docker hub是一个用于管理公共镜像的好地方,我们可以在上面找到我们想要的镜像,也可以把我们自己的镜像推送上去.但是,有时候,我们的使用场景需要我们拥有一个私有的镜像仓库用于管理 ...