下面是一个ADO方式连接Oracle的小程序部分代码......

首先是Oracle的配置、在Oracle的安装路径下找到:Oracle\network\ADMIN\tnsnames.ora文件、配置一下连接配置

  1. BOSS =
  2. (DESCRIPTION =
  3. (ADDRESS_LIST =
  4. (ADDRESS = (PROTOCOL = TCP)(HOST = xx.xx.xx.xx)(PORT = 1521))
  5. )
  6. (CONNECT_DATA =
  7. (SERVICE_NAME = boss)
  8. )
  9. )

新建一个头文件、名为CDBOperation.h:

  1. #pragma once
  2. #import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename("EOF", "adoEOF")
  3. class CDBOperation
  4. {
  5. public:
  6. //初始化数据库操作需要的对象
  7. CDBOperation(void);
  8. ~CDBOperation(void);
  9. //连接至数据库
  10. bool ConnToDB(char *ConnectionString, char *UserID, char *Password);
  11. //数据库操作函数
  12. //查询操作 删除以及添加
  13. _RecordsetPtr ExecuteWithResSQL(const char *);
  14. private:
  15. void PrintErrorInfo(_com_error &);
  16. private:
  17. //初始化数据库连接、命令、记录集
  18. _ConnectionPtr CreateConnPtr();
  19. _CommandPtr CreateCommPtr();
  20. _RecordsetPtr CreateRecsetPtr();
  21. private:
  22. //数据库连接需要的连接、命令操作对象
  23. _ConnectionPtr m_pConnection;
  24. _CommandPtr m_pCommand;
  25. };

新建一个c++源文件、名为CDBOperation.cpp:

  1. #include "stdafx.h"
  2. #include "DBOperation.h"
  3. CDBOperation::CDBOperation(void)
  4. {
  5. CoInitialize(NULL);
  6. m_pConnection = CreateConnPtr();
  7. m_pCommand = CreateCommPtr();
  8. }
  9. CDBOperation::~CDBOperation(void)
  10. {
  11. m_pConnection->Close();
  12. }
  13. bool CDBOperation::ConnToDB(char *ConnectionString, char *UserID, char *Password)
  14. {
  15. if (NULL == m_pConnection)
  16. {
  17. printf("Failed to create connection\n");
  18. return false;
  19. }
  20. try
  21. {
  22. HRESULT hr = m_pConnection->Open(ConnectionString, UserID, Password, NULL);
  23. if (TRUE == FAILED(hr))
  24. {
  25. return false;
  26. }
  27. m_pCommand->ActiveConnection = m_pConnection;
  28. return true;
  29. }
  30. catch(_com_error &e)
  31. {
  32. PrintErrorInfo(e);
  33. return false;
  34. }
  35. }
  36. _RecordsetPtr CDBOperation::ExecuteWithResSQL(const char *sql)
  37. {
  38. try
  39. {
  40. m_pCommand->CommandText = _bstr_t(sql);
  41. _RecordsetPtr pRst = m_pCommand->Execute(NULL, NULL, adCmdText);
  42. return pRst;
  43. }
  44. catch(_com_error &e)
  45. {
  46. PrintErrorInfo(e);
  47. return NULL;
  48. }
  49. }
  50. void CDBOperation::PrintErrorInfo(_com_error &e)
  51. {
  52. printf("Error infomation are as follows\n");
  53. printf("ErrorNo: %d\nError Message:%s\nError Source:%s\nError Description:%s\n", e.Error(), e.ErrorMessage(), (LPCTSTR)e.Source(), (LPCTSTR)e.Description());
  54. }
  55. _ConnectionPtr CDBOperation::CreateConnPtr()
  56. {
  57. HRESULT hr;
  58. _ConnectionPtr connPtr;
  59. hr = connPtr.CreateInstance(__uuidof(Connection));
  60. if (FAILED(hr) == TRUE)
  61. {
  62. return NULL;
  63. }
  64. return connPtr;
  65. }
  66. _CommandPtr CDBOperation::CreateCommPtr()
  67. {
  68. HRESULT hr;
  69. _CommandPtr commPtr;
  70. hr = commPtr.CreateInstance(__uuidof(Command));
  71. if (FAILED(hr) == TRUE)
  72. {
  73. return NULL;
  74. }
  75. return commPtr;
  76. }
  77. _RecordsetPtr CDBOperation::CreateRecsetPtr()
  78. {
  79. HRESULT hr;
  80. _RecordsetPtr recsetPtr;
  81. hr = recsetPtr.CreateInstance(__uuidof(Command));
  82. if (FAILED(hr) ==TRUE)
  83. {
  84. return NULL;
  85. }
  86. return recsetPtr;
  87. }

我的代码是放在MFC一个按钮Click事件里面的:

记住在处理事件的cpp文件中导入头文件:#include "DBOperation.h"

  1. CDBOperation dbOper;
  2. bool bConn = dbOper.ConnToDB("Provider=OraOLEDB.Oracle.1;Persist Security Info=True;Data Source=boss", "用户名", "密码");
  3. if (false == bConn)
  4. {
  5. MessageBox((LPCTSTR)"连接数据库出现错误\0",0,0);
  6. return;
  7. }
  8. //查询
  9. _RecordsetPtr pRst;
  10. char sql[255] = {0};
  11. strcpy(sql, " select * from boss_test_table2 where rownum = 1 ");
  12. pRst = dbOper.ExecuteWithResSQL(sql);
  13. if (NULL == pRst)
  14. {
  15. MessageBox(_T("查询数据出现错误!\0"),0,0);
  16. return;
  17. }
  18. if (pRst->adoEOF)
  19. {
  20. pRst->Close();
  21. MessageBox((LPCTSTR)"There is no records in this table\0",0,0);
  22. return;
  23. }
  24. _variant_t vSno, vName;
  25. while (!pRst->adoEOF)
  26. {
  27. //pRst->MoveFirst(); //记录集指针移动到查询结果集的前面
  28. vSno = pRst->GetCollect(_variant_t("U_NUMBER"));
  29. vName = pRst->GetCollect(_variant_t("USERS_NAME"));
  30. MessageBox((LPCTSTR)(_bstr_t)vSno,0,0);
  31. pRst->MoveNext();
  32. }
  33. strcpy(sql, "insert into boss_test_table2 (u_number, users_name, users_phone, status, customno_id) values ('0001', 'C+TTT+', '13999000000', 2, 'BPPPPPPPPPP')");
  34. pRst = dbOper.ExecuteWithResSQL(sql);
  35. if (NULL != pRst)
  36. {
  37. AfxMessageBox(_T("插入数据成功\n"));
  38. }
  39. //执行删除语句
  40. sprintf(sql, "delete boss_test_table2 where u_number = '%s'", "009");
  41. pRst = dbOper.ExecuteWithResSQL(sql);
  42. if (NULL != pRst)
  43. {
  44. MessageBox(_T("删除数据成功\0"),0,0);
  45. }
  46. //执行更新语句
  47. sprintf(sql, "update boss_test_table2 set users_name = '%s' ", "C++反人类、MFC反社会");
  48. pRst = dbOper.ExecuteWithResSQL(sql);
  49. if (NULL != pRst)
  50. {
  51. MessageBox(_T("更新数据成功\0"),0,0);
  52. }

C++ 连接Oracle的更多相关文章

  1. 一起学微软Power BI系列-使用技巧(1)连接Oracle与Mysql数据库

    说起Oracle数据库,以前没用过Oracle不知道,但是这1年用Oracle后,发现真的是想狂吐槽,特别是那个.NET驱动和链接字符串,特别奇葩.总归是和其他数据库不一样,标新立异,不知道为何.另外 ...

  2. Linux下部署ASP.NET服务连接oracle遇到的问题记录

    一.如何卸载MONO Q:mono是linux系统上跨平台软件,卸载它有两种方式: 1.知道mono安装路径,安装原来的路径直接覆盖安装(最为简单): 2.不知道mono安装路径,首先通过sudo f ...

  3. Java JDBC Thin Driver 连接 Oracle 三种方法说明(转载)

    一.JDBC 连接Oracle 说明 JDBC 的应用连接Oracle 遇到问题,错误如下: ORA-12505,TNS:listener does not currently know of SID ...

  4. 关于ADO.NET连接ORACLE,使用ODAC连接中的一些问题

    ADO.NET连接ORACLE时,用到ODAC组件时,有几点注意的. 1.安装的具体方法见:http://jingyan.baidu.com/article/e4511cf336ce872b845ea ...

  5. Qgis连接Oracle

    CMake编译中选择编译Oracle一项以后,编译的qgis才会有连接Oracle数据库的功能. 编译qgis以后,可以通过添加矢量图层中选择Oracle数据库,或是添加Oracle空间图层,或是添加 ...

  6. IIS 连接 oracle报Oracle.DataAccess版本错误解决办法

    通过IIS连接oracle时报“Could not load file or assembly 'Oracle.DataAccess, Version=2.112.3.0, Culture=neutr ...

  7. 使用Navicat连接Oracle数据时的一些问题,连接时错误:ORA-28547,新建用户后连接时错误:ORA-01017

    发现Navicat作为一款连接数据库的工具确实很好用,可视化的界面看着舒服很多,下面说说我今天在连接Oracle数据库时的一些问题: 1.安装好Oracle后直接用Navicat是连接不上的,会出现如 ...

  8. mac版本navicat连接oracle报错ORA-21561

    最近电脑更换成mac,很多软件都和win不一样了,正在慢慢适应,连接oracle原来用的客户端是pl/sql develop,蛋疼的是没有了mac版本, 用了navicat,具体设置如下 1.新建连接 ...

  9. Java连接Oracle database小结

    利用jdbc连接Oracle数据库,首先得选对jdbc的版本. jdk6需要ojdbc6.jar这个包.如果选错的话,调用isValid()这个方法时,有可能有这个异常: Exception in t ...

  10. 不安装oracle客户端,用plsql连接oracle

    常用的Oracle开发的工具有SQL Developer和PL/SQL Developer,个人感觉前者虽然跨平台性优于后者,但比较大(大于300M)占用资源,而且用户体验也一般,而后者相对就小很多( ...

随机推荐

  1. is与==

     is和==的区别 1. id() 通过id()我们可以查看到⼀一个变量表示的值在内存中的地址. a1 = 100 b1 = 100 print(id(a1),id(b1)) #14071247240 ...

  2. [UE4]计算小地图比例尺

    一.调整到顶视图,按住鼠标中键从地图的左边拉一根线到右边,可以看到距离是4000厘米(UE4单位是厘米). 二.查看到缩略图片的长度是512px,512/4000 = 0.128,比例尺是0.128. ...

  3. [UE4]第一人称与第三人称

    一.给Character添加一个SkeletalMesh,并设置为第三人称模型.并设置自己看不到该模型. 二.添加给骨骼的右手添加一个Socket插槽用来挂载武器 三.判断当前角色是否被本地Contr ...

  4. Mybatis 系列5-结合源码解析TypeHandler

    [Mybatis 系列10-结合源码解析mybatis 执行流程] [Mybatis 系列9-强大的动态sql 语句] [Mybatis 系列8-结合源码解析select.resultMap的用法] ...

  5. 挂载本地iso镜像

    挂载本地iso镜像 [root@linux-node1 ~]# mkdir -p /disk/iso [root@linux-node1 ~]# cd /disk/iso/ [root@linux-n ...

  6. jQuery动态创建DOM节点

    var SKU=$("#SKU"); // 通过ID查找到指定表格 var oTable=SKU[0]; // 获取第一个表格 // 获取正文tbody元素 var tBodies ...

  7. unhandledException

    处理未捕获的异常是每个应用程序起码有的功能,C#在AppDomain提供了UnhandledException 事件来接收未捕获到的异常的通知.常见的应用如下: static void Main(st ...

  8. 《Linux 性能及调优指南》1.6 了解Linux性能指标

    翻译:飞哥 (http://hi.baidu.com/imlidapeng) 版权所有,尊重他人劳动成果,转载时请注明作者和原始出处及本声明. 原文名称:<Linux Performance a ...

  9. nvm-windows安装

    linux上的nvm太好用了,windows也出了,不过需要手动下载安装 地址: https://github.com/coreybutler/nvm-windows/releases 博主安装的是 ...

  10. MVC Html辅助方法DropDownList的简单使用、连接MYSQL数据库用自定义model类接收

    附上启发链接:https://www.cnblogs.com/CreateMyself/p/5424894.html [HttpGet] public ActionResult Edit(int id ...