引用: http://blog.csdn.net/u011311985/article/details/51221898

测试程序我放到 http://download.csdn.NET/detail/u011311985/9499596这个地址中了,有需要的朋友可以下载

一、下载客户端驱动说明

参考网址:

使用ocilib;
http://wenku.baidu.com/link?url=9pHYVD-MEq00_a0E80gzm3fHf7pICM0KsWrrgYAqlnKLpl2OlKnAo5qKM3qtK-oMg1XvcMYfJeciuomYSFDFywDNsyT1O6WfXFQ-Zi3j6zy

VC++中连接Oracle数据库的几种方法:
http://wenku.baidu.com/link?url=28YGj8UHqEmnhOa9BaRCSOI6w_f-QUomD0tjb3rFdEzxZ_8G0LkoCULOnYS0icX6u1KrUIhXPynyDIJPnVQDzlJn_-tlpIdJ1qA1m2IqtsW

OCI接口简介及其在VC++中的应用:
http://blog.csdn.net/cherishlei/article/details/4398867

C++使用OCI连接Oracle :
http://blog.chinaunix.net/uid-21592001-id-3271863.html

Pro*C  OCI  OCCI  及OCI介绍:
http://blog.sina.com.cn/s/blog_4b3c1f950100pvzx.html

OCI编程历程

http://www.cnblogs.com/ychellboy/archive/2010/04/16/1713884.html

使用点:
1、下载instantclient和ocilib(太大,我没有上传,不过需要的东西(除了sqlplus)我都上传并放到测试程序的ocilib目录中和debug目录中了)
    我的instantclient有instantclient-basic-nt-11.2.0.4.0、instantclient-odbc-nt-11.2.0.4.0、instantclient-sdk-nt-11.2.0.4.0、instantclient-sqlplus-nt-11.2.0.4.0
    我的ocilib是ocilib-4.1.0-windows(这里面有demo示例)
    
2、解压下载的压缩包(合并那几个instantclient为instantclient_11_2,程序运行需要知道这个目录)

3、ping服务器地址,telnet查看服务器端口能否访问
    本地cmd访问服务器oracle
    cmd定位到sqlplus.exe所在的目录中(比如,instantclient-sqlplus-nt-11.2.0.4.0目录中就会含有sqlplus.exe)
    > sqlplus /nolog
    > conn 用户名/密码@服务器地址:端口/数据库SID
    eg:conn test/qiantangjiang@192.168.2.201:1521/ORCL

4、运行ocilib-4.1.0-windows的示例(在ocilib-4.1.0-windows\ocilib\proj\test中)可以测试是否能连上服务器的数据库
    运行ocilib的demo时需要把lib32下的dll和lib放到debug中

二、测试程序说明

我的系统是32位,用的Unicode编码

这些文件在下载客户端驱动之后都有(我已经放到我的ocilib目录中和debug目录中了)

访问Oracle数据库需要3个dll文件:oci.dll、ociliba.dll、oraociei11.dll放到和运行程序同一个目录下(比如Debug下)
还要添加环境变量:NLS_LANG 值为 SIMPLIFIED CHINESE_CHINA.ZHS16GBK(不然的话向数据库插入中文会是乱码)

我建了ocilib目录
    ocilib目录中有两个子目录,分别是include和lib32
    include中有ocilib.h        ocilib.hpp        ocilib_core.hpp        ocilib_impl.hpp
    lib32中有libocilib.a、libocilibw.a、ociliba.dll、ociliba.lib、ocilibw.dll、

VS2013属性配置:
字符集:Unicode字符集
(工程|属性|调试)环境:path=..\ocilib\lib32
(工程|属性|C/C++|常规)附加包含目录:..\ocilib\include
(工程|属性|连接器)附加库目录:..\ocilib\lib32

程序中还有
#pragma comment(lib, "..\\ocilib\\lib32\\ociliba.lib")

包含头文件
#include "ocilib.hpp"

初始化操作
Environment::Initialize(Environment::Default,"oci.dll和oraociei11.dll的目录");//第二个参数就是上述lib目录

三、程序展示

    1. #include <string>
    2. #include <iostream>
    3. #include <iomanip>
    4. #include "ocilib.hpp"
    5. #pragma comment(lib, "..\\ocilib\\lib32\\ociliba.lib")
    6. int main()
    7. {
    8. using namespace ocilib;
    9. using namespace std;
    10. //当前程序路径
    11. string szlibpath = "E:\\shuaizy\\Trunk\\oracletest\\Debug";
    12. try
    13. {
    14. Environment::Initialize(Environment::Default, szlibpath);
    15. Connection con("192.168.2.201/orcl", "test", "qiantangjiang");//实例、用户名、密码
    16. Statement st(con);
    17. st.Execute("select * from all_users order by user_id");
    18. Resultset rs = st.GetResultset();
    19. while (rs++)
    20. {
    21. std::cout << std::setw(30) << std::left << rs.Get<ostring>("username")
    22. << std::setw(10) << std::right << rs.Get<ostring>("user_id")
    23. << std::setw(20) << std::right << rs.Get<ostring>("created") << std::endl;
    24. }
    25. //std::cout << "=> Total fetched rows : " << rs.GetCount() << std::endl;
    26. cout << "执行语句:\r\nselect * from all_users order by user_id\r\n查询到 "
    27. << rs.GetCount() << " 条数据" << endl;
    28. }
    29. catch (std::exception &ex)
    30. {
    31. std::cout << ex.what() << std::endl;
    32. }
    33. Environment::Cleanup();
    34. return 0;
    35. }

C++使用ocilib访问oracle数据库的更多相关文章

  1. .net(C#)访问Oracle数据库的几种免安装组件的对比

    Oracle 数据存取组件(ODAC) 库为Borland Delphi,C++ Builder 以及 Kylix提供了一些非可视化的组件.它们用来存取Oracle关系数据库系统.与BDE类似, OD ...

  2. 基于OCILIB的oracle数据库操作总结及自动生成Model和Dao的工具

    基于OCILIB的oracle数据库操作总结 1.       类图 2.       基类BaseOCIDao的设计与实现 BaseOCIDao.h头文件 #pragma once /* ----- ...

  3. 用JDBC访问ORACLE数据库 关于commit 增快效率 大数据 等的整理

    1.问:用JDBC访问ORACLE数据库,做DELETE操作,能用JAVA多线程实现吗? ORACLE服务器要怎么配?(以下答案来自网络,仅供参考) 答: Oracle有自己的锁机制.就算你开100条 ...

  4. .net(C#)访问Oracle数据库的几种免安装组件的对比(转)

    原文地址 [内容为转载,个人推荐还是用官方的组件,推荐使用 Oracle.DataAccess.dll ] .net(C#)编程过程中,使用到了以下三种免安装的Oracle访问组件,能够不安装Orac ...

  5. 运行于64操作系统上的C#客户端通过WCF访问Oracle数据库不兼容问题

    运行平台: Windows 7  64位操作系统 运行环境: IIS 7 编程语言:C# 数据库: 32位的Oracle 10g 运行原因:64位操作系统C#客户端程序通过WCF访问ORACLE数据库 ...

  6. ODP.NET 之访问 Oracle 数据库

    ODP.NET 之访问 Oracle 数据库 要相使用 Oracle Data Provider For .NET(ODP.NET), 必须先安装 ODP.NET 或者是 ODAC(Oracle Da ...

  7. 【方法】如何限定IP访问Oracle数据库

    [方法]如何限定IP访问Oracle数据库 1.1  BLOG文档结构图 1.2  前言部分 1.2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知 ...

  8. c#访问oracle数据库

    想在c#中访问oracle数据库,毕竟是开发,想要轻量级访问oracle,客户机上无需安装oracle环境就能正常运行程序. 在网上找了相关资料,只需要引用一个dll即可实现. 访问代码(需引用dll ...

  9. WebService访问oracle数据库本地调试

    WebService访问oracle数据库本地调试-一步一个坑 上篇文章提到我们额数据库挂了,重装了数据库,然后呢我需要在本地调试WebService,看看那些数据结构缺失,迁移到新数据库中去.踩坑之 ...

随机推荐

  1. urlretrieve 如何给文件下载设置下载进度?

    #python #xiaodeng #如何给文件下载设置下载进度? import urllib def callbackinfo(down,block,size): ''' 回调函数: down:已经 ...

  2. LEGO机器人发展史

    1998,cybermaster 1999,RCX 1999,micro scout 2000,scout 2002,spybotics NXT NXT2 EV3

  3. lua入门之二:c/c++ 调用lua及多个函数返回值的获取

    当 Lua 调用 C 函数的时候,使用和 C 调用 Lua 同样类型的栈来交互. C 函数从栈中获取她的參数.调用结束后将返回结果放到栈中.为了区分返回结果和栈中的其它的值,每一个 C 函数还会返回结 ...

  4. 【mysql】Innodb三大特性之insert buffer

    一.什么是insert buffer insert buffer是一种特殊的数据结构(B+ tree)并不是缓存的一部分,而是物理页,当受影响的索引页不在buffer pool时缓存 secondar ...

  5. 【LeetCode】14. Longest Common Prefix (2 solutions)

    Longest Common Prefix Write a function to find the longest common prefix string amongst an array of ...

  6. 配置tomcat全局c3p0连接池

    由于项目中多个应用访问同一个数据库,并部署在同一个tomcat下面,所以没必要每个应用都配置连接池信息,这样可能导致数据库的资源分布不均,所以这种情况完全可以配置一个tomcat的全局连接池,所涉及应 ...

  7. Clipboard.GetImage() Clipboard获取粘贴板内容为null的解决办法

    将线程启动模式设置为 sta 单线程 简介 STA:   Single-Thread   Apartment,   中文叫单线程套间.就是在COM库初始化的时候创建一个内存结构,然后让它和调用CoIn ...

  8. Jmete ----r默认报告优化

    转自:http://www.cnblogs.com/puresoul/p/5053035.html 一.本文目的: 之前写了两篇文章搭建持续集成接口测试平台(Jenkins+Ant+Jmeter)和A ...

  9. UNIX域套接字编程和socketpair 函数

    一.UNIX Domain Socket IPC socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是UNIX Domain Socket.虽然网络soc ...

  10. du和df命令的区别

    du和df命令都被用于获得文件系统大小的信息:df用于报告文件系统的总块数及剩余块数,du -s /<filesystem>用于报告文件系统使用的块数.但是,我们可以发现从df命令算出的文 ...