oracle oic配置,Oracle数据库 client配置

以下是11g client配置

1. 从OTN下载几个压缩包

下载地址为: http://www.oracle.com/technology/software/tech/oci/instantclient/index.html

然后根据你的平台,选择不同的下载,我是安装在rhel5下,所以选择了linux x86 并下载了下面2个包:

instantclient-basic-linux32-11.1.0.7.zip  基本包,提供了OCI,OCCI和JDBC-OCI应用程序的支持。

instantclient-sdk-linux32-11.1.0.7.zip  附加的头文件和makefile文件,部分需要编译的模板需要,比如编译php的oci8,和python 的cx_Oracle. (我们这里仅使用其提供的oci头文件)

instantclient-sqlplus-linux32-11.1.0.7.zip 可选安装,sqlplus有时候测试,管理什么的很方便。

1.建立oracle用户和组:

#groupadd oinstall

#useradd -g oinstall oracle

#passwd oracle

2.建立一个Oracle 基本目录

#mkdir –p /usr/local/oracle

#chown –R oracle:oinstall /usr/local/oracle

#chmod –R 775 /usr/local/oracle

将上述tar.gz或zip包解压,拷贝到 /usr/local/oracle目录中。

3.设置 ORACLE_HOME和LD_LIBRARY_PATH环境变量,配置TNS_ADMIN变量(放置 tnsname.ora的目录)。如果使用sqlplus的话,也设置下PATH环境变量。修改oracle用户目录下的  .bash_profile加入下面语句。

export ORACLE_HOME=/usr/local/oracle

#export ORACLE_SID=hbdb

export SQLPATH=/usr/local/oracle

#寻找tnsnames.ora路径

export TNS_ADMIN=/usr/local/oracle

export NLS_LANG=''american_america.ZHS16GBK''

export LD_LIBRARY_PATH=$ORACLE_HOME:$LD_LIBRARY_PATH

export PATH=$PATH:$ORACLE_HOME

4.tnsnames.ora配置:

MYDB =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 10.0.0.5)(PORT = 1521))

)

(CONNECT_DATA =

(SID = HBDB)

(SERVER = DEDICATED)

)

)

5.sqlplus连接数据库:

sqlplus user/passwd@10.0.0.5/hbdb或sqlplus user/passwd@MYDB

如果出现:sqlplus: error while loading shared libraries: /usr/local/oracle/libnnz11.so: cannot restore segment prot after reloc: Permission denied

最简单的解决方法莫过于将SElinux设置位PERMISSIVE状态:

[root@localhost ~]# getenforce

Enforcing

[root@localhost ~]# setenforce 0

[root@localhost ~]#  getenforce

Permissive

[oracle@localhost ~]# sqlplus xfdb/xfdb@MYDB

SQL*Plus: Release 11.1.0.7.0 - Production on Wed Jun 17 16:37:06 2009

Copyright (c) 1982, 2008, Oracle.  All rights reserved.

Connected to:

Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - 64bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> select sysdate from dual;

SYSDATE

------------

17-JUN-09

SQL>

6.测试eams项目数据库访问组件dboci(对oci的c++封装)

先建立一个libclntsh.so.11.1的链接:

[oracle@localhost oracle]# ln -s libclntsh.so.11.1  libclntsh.so

#include "dboci.h"

#include

int main(void)

{

CDbOci oci;

int iret = oci.Open("xfdb", "xfdb", "HBDB");

if (iret < 1)

return 0;   //

char*** result = NULL;

int num = oci.Query("select sysdate from dual", &result, 1);

if (num > 0)

{

for (int i=0; i < num; i++)

{

std::cout 《result[i][0] 《std::endl;

}

oci.FreeExecSqlBuf(&result, num, 1);

}

oci.Close();

return 1;

}

scons脚本:

env = Environment()

env.Append(CCFLAGS='-g')

src_files = Split('DBconnect.cpp /dboci/source/dboci.cpp')

include = Split('/usr/local/oracle/sdk/include /dboci/include')

lib_path = Split('/usr/local/oracle')

lib_files = Split('clntsh nnz11')

env.Program(target='dbconnect',source = src_files, LIBS=lib_files, LIBPATH=lib_path,CPPPATH=include)

运行结果:

[root@localhost dbconnecttest]# ./dbconnect

17-JUN-09

至此eams项目数据库存取的开发与部署测试通过!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/503292.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 反射机制和动态代理是基于什么原理,了解过吗?

工作多年以及在面试中&#xff0c;我经常能体会到&#xff0c;有些面试者确实是认真努力工作&#xff0c;但坦白说表现出的能力水平却不足以通过面试&#xff0c;通常是两方面原因&#xff1a; 1、“知其然不知其所以然”。 做了多年技术&#xff0c;开发了很多业务应用&#x…

oracle执行sql痕迹,Oracle 查询刚执行的SQL

Oracle 查询刚刚执行的SQLselect "SQL_TEXT","SQL_FULLTEXT","SQL_ID","SHARABLE_MEM","PERSISTENT_MEM","RUNTIME_MEM","SORTS","LOADED_VERSIONS","OPEN_VERSIONS","USERS_…

成长为一名Java架构师需要掌握的技术有哪些呢?

Java架构师需要掌握的技术&#xff1a; 1、熟练使用各种框架&#xff0c;并知道它们实现的原理。 2、jvm虚拟机原理、调优&#xff0c;懂得jvm能让你写出性能更好的代码&#xff1b; 3、池技术&#xff0c;什么对象池&#xff0c;连接池&#xff0c;线程池……Java反射技术&…

php 分布式数据库查询,分布式数据库

# 分布式数据库ThinkPHP内置了分布式数据库的支持&#xff0c;包括主从式数据库的读写分离&#xff0c;但是分布式数据库必须是相同的数据库类型。配置database.deploy 为1 可以采用分布式数据库支持。如果采用分布式数据库&#xff0c;定义数据库配置信息的方式如下&#xff1…

Java程序员遇到瓶颈后我们可以试着朝四个方向拓展?你们觉得呢?

现如今随着IT行业的火热&#xff0c;人们对于编程技术也是越来越关注重视&#xff0c;在从业后我们做Java开发难免会遇到一些瓶颈。在我看来解决这个问题一般有以下4种方向&#xff1a; 基于产品本身 要记住公司招人是解决问题的&#xff0c;基于现有问题出发&#xff0c;大家…

oracle 布尔盲注,Oracle基于延时的盲注总结

0x00 前言oracle注入中可以通过页面响应的状态&#xff0c;这里指的是响应时间&#xff0c;通过这种方式判断SQL是否被执行的方式&#xff0c;便是时间盲注&#xff1b;oracle的时间盲注通常使用DBMS_PIPE.RECEIVE_MESSAGE()&#xff0c;而另外一种便是decode()与高耗时SQL操作…

Java架构师除了必备的技术之外,这些技能也需必备?你们觉得呢?

成为Java架构师首先你必须是一名Java高级开发工程师&#xff0c;熟练使用各种框架&#xff0c;并且能知道他们其中的原理。jvm虚拟机原理、调优&#xff0c;懂得jvm能让你写出性能更好的代码;池技术&#xff0c;什么对象池&#xff0c;连接池&#xff0c;线程池等等 Java构架师…

bat oracle导出数据库,bat命令oracle自动备份

echo offecho echo windows环境下Oracle数据库的自动备份脚本echo 说明&#xff1a;启动备份时&#xff0c;需要配置以下变量echo 1、BACKUP_DIR 指定要备份到哪个目录echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码ech…

Java编程学习并不难,有坚持的动力与良好的心态尤为重要

时间过得很快&#xff0c;回想刚学习Java编程开发的懵懂无知&#xff0c;到现在可以做出简单的项目&#xff0c;可以明显的感觉到自己确实进步了。Java编程其实并不难学&#xff0c;难的是你能够一如既往的保持好的学习态度&#xff0c;并愿意努力的去背、去记、去做项目练习。…

php常用函数、算法,PHP常用函数和常量

PHP常用系统常量__FILE__文件的完整路径和文件名。如果用在被包含文件中&#xff0c;则返回被包含的文件名。自 PHP 4.0.2 起&#xff0c;总是包含一个绝对路径(如果是符号连接&#xff0c;则是解析后的绝对路径)&#xff0c;而在此之前的版本有时会包含一个相对路径。__DIR__文…

Java编程开发中高效编码的7个技巧?你应该知道……

1. 使用 JDK 8 或更高版本 从 JDK 8 以及 更高版本开始&#xff0c;引进许多新功能将允许你编写更短、更具表现力的代码&#xff0c;包括 lambda 表达式、functional 接口、stream API等。你实际上不需要记住他们&#xff0c;因为 IDEA 将帮助你使用这些功能&#xff0c;这也是…

下载jdk一定要登录oracle么,如何下载oracle jdk|oracle jdk下载慢,要登录等等问题

/java/jdk/8u231-b11/5b13a193868b4bf28bcb45c792fce896/jdk-8u231-linux-x64.tar.gz注意替换--------------------------------------------附上一批网址&#xff0c;这些应该也够了http://ns1.iranns.ir 这个比较新https://mirrors.huaweicloud.com/java/http://enos.itcoll…

oracle 11g segment,11g视图dba_segments中增加了一个有用的segment_subtype字段!

以前我们要查一个segment所在的表空间是assm还是mssm&#xff0c;需要查看这个segment所在的表空间的segment_space_management 字段属性&#xff0c;在11g中不需要了&#xff0c;只需要查看dba_segments的segment_subtype就可以了&#xff0c;看似一个小小的改进&#xff0c;却…

谈谈Java与大数据之间的关系你们都了解了清楚了吗?

Java是计算机编程语言界的王者&#xff0c;大数据是当下IT领域中最新潮的技术&#xff0c;Java和大数据都是当下十分受企业欢迎的IT技术&#xff0c;也是企业核心竞争力的重要组成部分&#xff0c;都说学大数据要先学Java&#xff0c;那么Java和大数据有什么关系呢&#xff1f;…

linux用户组chownd,Linux系统centos6下用户与用户组权限命令用法 chmod与chown

查看当前目录下文件的权限&#xff1a;命令&#xff1a;ll 或&#xff1a;ls -l-rw-r--r--. 1 root root 6 Nov 9 16:42 abc.htmldrw-r--r--. 1 root root 6 Nov 9 16:42 pages其中“-rw-r–r–”表示权限&#xff0c;一共有十个字符。第一个字符&#xff0c;如果是“-”则表示…

自学Java必看的知识点,猿们怎么看?

1.你需要精通面向对象分析与设计(OOA/OOD)、涉及模式(GOF&#xff0c;J2EEDP)以及综合模式。你应该了解UML&#xff0c;尤其是class、object、interaction以及statediagrams。 2. 你需要学习Java语言的基础知识以及它的核心类库(collections、serialization、streams、network…

linux 源码包编译,源码包编译安装

程序包编译安装&#xff1a;Application-VERSION-release.src.rpm–> 安装后&#xff0c;使用rpmbuild命令制作成二进制格式的rpm包&#xff0c;而后再安装源代码 –> 预处理 –> 编译 –> 汇编 –> 链接 –> 执行源代码组织格式&#xff1a;多文件&#xff…

谈一谈Java编程开发中虚拟机的内存区域划分?猿们怎么看?

java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域&#xff0c;有的区域随虚拟机进程的启动而存在&#xff0c;有的区域则依赖线程而存在。包括以下几个运行时数据区域&#xff1a; 程序计数器&#xff08;线程私有&#xff09;&#xff1a; 可以…

linux桌面使用网卡设置,Linux的KDE桌面下怎样设置网络连接?

a) 在KDE的“启动程序”菜单&#xff0c;选择“KNOPPIX”—>“Network/Internet”—>点击“ADSL/PPPOE configuration”。b) 配置程序会自动找到您的网卡设备&#xff0c;确认后请选中“yes”并回车。c) 程序自动扫描已安装的ADSL Modem。d) 已找到ADSL Modem&#xff0c…

成为一名成功的程序员要做到以下10点?网友:是真的吗?

编程是一个没有极限的职业&#xff0c;所以要成为一名优秀的程序员&#xff0c;你必须超越现有已存在的极限。在程序员职业生涯的开始阶段&#xff0c;他们将面临许多挑战&#xff0c;面对困境&#xff0c;他们之中有一些人将会放弃&#xff0c;而只有少数人会坚持到底&#xf…