在CentOS 6.6上搭建C++运行环境并连接Oracle数据库

简介:

1、安装运行环境

1
# yum install gcc-c++

备注:此时会将gcc-c++和libstdc++-devel都安装上。


2、查看g++是否安装成功

1
[root@MyRHEL 桌面] # g++ -v

使用内建 specs。

目标:x86_64-redhat-linux

配置为:../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-bootstrap --enable-shared --enable-threads=posix --enable-checking=release --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-languages=c,c++,objc,obj-c++,java,fortran,ada --enable-java-awt=gtk --disable-dssi --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-1.5.0.0/jre --enable-libgcj-multifile --enable-java-maintainer-mode --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --disable-libjava-multilib --with-ppl --with-cloog --with-tune=generic --with-arch_32=i686 --build=x86_64-redhat-linux

线程模型:posix

gcc 版本 4.4.7 20120313 (Red Hat 4.4.7-11) (GCC) 


3、测试

(1)测试C语言程序testc.c

1
2
3
4
5
6
#include<stdio.h>
int  main()
{
    printf ( "Hello C!\n" );
    return  0;
}

运行:

1
2
# gcc testc.c -o testc
# ./testc

(2)测试C++程序test.cpp

1
2
3
4
5
6
7
8
9
#include <iostream>    
using  namespace  std;                      
int  main()                                  
{                                            
     cout <<  "Come up and C++ me some time." ;  
     cout << endl;                             
     cout <<  "You won't regret it!"  << endl;   
     return  10;                                 
}

运行:

1
2
# g++ -o test1 test.cpp
# ./test1


4 安装OracleClient

主要安装oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpmoracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm

1
2
# rpm -ivh oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm
# rpm –ivh oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm


5 配置

1)配置ld.so.conf文件,填入如下内容:

1
2
3
# vi /etc/ld.so.conf
include ld.so.conf.d/*.conf
/usr/lib/oracle/11 .2 /client64/lib

2)配置/etc/hosts文件(此处填入Linux系统主机的IP地址和主机名称),填入如下内容:

1
2
3
4
# vi /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.48.128 MyRHEL


6 测试与Oracle数据库连接

1)建立一个connclient.cpp文件,输入如下内容:

[root@MyRHEL test]# vi connclient.cpp

 

#include<iostream>

#include<string>

#include<occi.h>

using namespace std;

using namespace oracle::occi;

int main()

{

     Environment *env;

     Connection *conn;

     Statement *stmt;

     string struser("scott");

     string strpwd("Orcl0991");

     string strconn_string("10.208.17.206:1521/xe");

     env = Environment::createEnvironment(Environment::OBJECT);

     conn = env->createConnection(struser, strpwd, strconn_string);

     if(NULL!= conn)

               cout <<"conn success"<< endl;

     else

               cout <<"conn failed"<<endl;    

 

     string strsql("select deptno,dname from dept");

     stmt = conn->createStatement(strsql);

     ResultSet *rset = stmt->executeQuery();

     while(rset->next()){

               int deptno = rset->getInt(1);

               string dname = rset->getString(2);

               cout<<"deptno="<<deptno<<",dname="<<dname<<endl;

     }

     stmt->closeResultSet(rset);

     conn->terminateStatement(stmt);

     env->terminateConnection(conn);

     Environment::terminateEnvironment(env);

     return0;

}

 

2)编译运行:

1
2
3
4
5
6
7
[root@MyRHEL test]# g++ -o connclient  connclient.cpp -L /usr/lib/oracle/11.2/client64/lib  -I /usr/include/oracle/11.2/client64/  -locci  -lclntsh  /usr/lib64/libstdc++.so.6
[root@MyRHEL test]# ./connclient
conn success
deptno=10,dname=ACCOUNTING
deptno=20,dname=RESEARCH
deptno=30,dname=SALES
deptno=40,dname=OPERATIONS


     本文转自stock0991 51CTO博客,原文链接:http://blog.51cto.com/qing0991/1700679,如需转载请自行联系原作者







相关文章
|
13天前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库(一):装上去,飞起来!
【Oracle】玩转Oracle数据库(一):装上去,飞起来!
54 7
|
13天前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库(七):RMAN恢复管理器
【Oracle】玩转Oracle数据库(七):RMAN恢复管理器
40 5
|
5天前
|
存储 Oracle 关系型数据库
Oracle的模式与模式对象:数据库的“城市规划师”
【4月更文挑战第19天】在Oracle数据库中,模式是用户对象的集合,相当于数据库的城市规划,包含表、视图、索引等模式对象。模式对象是数据存储结构,如表用于存储数据,视图提供不同查看角度,索引加速数据定位。良好的模式与模式对象设计关乎数据效率、安全和稳定性。规划时需考虑业务需求、性能、安全和可扩展性,以构建高效数据库环境,支持企业业务发展。
|
9天前
|
JavaScript 关系型数据库 MySQL
❤Nodejs 第二章(Node连接本地数据库)
【4月更文挑战第2天】本文介绍了如何使用Node.js连接本地MySQL数据库。首先,提到了在MySQL官网下载安装数据库和使用Navicat for MySQL进行数据库管理。接着,通过`yarn add mysql`在项目中安装数据库依赖。然后,创建`app.js`文件,设置数据库连接参数,并建立连接进行查询操作。遇到导入模块的错误后,修改导入方式为CommonJS语法。
26 1
|
12天前
|
SQL 监控 关系型数据库
PG数据库释放闲置连接
PG数据库释放闲置连接
19 0
|
13天前
|
存储 SQL Oracle
【Oracle】玩转Oracle数据库(二):体系结构、存储结构与各类参数
【Oracle】玩转Oracle数据库(二):体系结构、存储结构与各类参数
35 7
|
22天前
|
弹性计算 关系型数据库 MySQL
阿里云数据库服务器价格表,数据库创建、连接和使用教程
阿里云数据库使用流程包括购买和管理。选择所需数据库类型如MySQL,完成实名认证后购买,配置CPU、内存和存储。确保数据库地域与ECS相同以允许内网连接。创建数据库和账号,设置权限。通过DMS登录数据库,使用账号密码连接。同一VPC内的ECS需添加至白名单以进行内网通信。参考官方文档进行详细操作。
123 3
|
23天前
|
网络协议 数据库连接 网络安全
DM数据库连接数据库时报:创建sokect连接失败
DM数据库连接数据库时报:创建sokect连接失败
13 0
|
1天前
|
Linux
centos 6.5安装yum
centos 6.5安装yum
10 0
|
1天前
|
运维 网络协议 Linux
【运维系列】Centos7安装并配置PXE服务
PXE是Intel开发的预启动执行环境,允许工作站通过网络从远程服务器启动操作系统。它依赖DHCP分配IP,DNS服务分配主机名,TFTP提供引导程序,HTTP/FTP/NFS提供安装源。要部署PXE服务器,需关闭selinux和防火墙,安装dhcpd、httpd、tftp、xinetd及相关服务,配置引导文件和Centos7安装源。最后,通过syslinux安装引导文件,并创建pxelinux.cfg/default配置文件来定义启动参数。
5 0