oracle 11g即时客户端配置详解

news/2024/7/7 19:06:09 标签: oracle, path, 数据库, library, 数据库服务器, include

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 <iostream>

    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项目数据库存取的开发与部署测试通过!

  • 顺带说明下oracle 11g即时客户端在windows下的配置

    1.  假设把压缩文件解压到d盘根目录;

    2.     编辑环境,将d:/instantclient_11_1添加到PATH中(注意位于其他Oracle目录之前),增加系统环境变量TNS_ADMIN设置为d:/instantclient_11_1;ORACLE_HOME设置为d:/instantclient_11_1;NLS_LANG为''american_america.ZHS16GBK''

    例如,在Windows 2000上,依次单击“开始”->“设置”->“控制面板”->“系统”->“高级”->“环境变量”,编辑系统变量列表中的PATH,系统环境变量TNS_ADMIN设置为d:/instantclient_11_1;系统环境变量ORACLE_HOME设置为d:/instantclient_11_1;系统环境变量NLS_LANG设置为american_america.ZHS16GBK

    3.     编辑d:/instantclient_11_1/ tnsnames.ora文件:

    MYDB =
      (DESCRIPTION =
        (ADDRESS_LIST =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 10.0.0.5)(PORT = 1521))
        )
        (CONNECT_DATA =
          (SID = HBDB)
          (SERVER = DEDICATED)
        )
      )

    其中:MYDB:数据库的事例名

    10.0.0.5数据库服务器地址

    HBDB:数据库的SID;

http://blog.163.com/yu_hongchang/blog/static/39894138200951741039997/


http://www.niftyadmin.cn/n/1051017.html

相关文章

Struts 2中实现文件上传

前一阵子有些朋友在电子邮件中问关于Struts 2实现文件上传的问题&#xff0c; 所以今天我们就来讨论一下这个问题。 实现原理 Struts 2是通过Commons FileUpload文件上传。Commons FileUpload通过将HTTP的数据保存到临时文件夹&#xff0c;然后Struts使用fileUpload拦截器将文…

Spring和ActiveMq消息队列整合详解

Spring和ActiveMq消息队列整合详解 官方主页 Spring ActiveMq 一、概述 消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流&#xff0c;并基于数据通信来进行分布式系统的集成。通过提供消息传递和消息排队模型&#xff0c;它可以在分布式环境下扩展进程间的通…

How does a single thread handle asynchronous code in JavaScript?

原文&#xff1a; https://www.quora.com/How-does-a-single-thread-handle-asynchronous-code-in-JavaScript -------------------------------------------------------------------------------- Well, arguably its not true that Javascript is single threaded if you se…

java数据库设计中的14个技巧(zhuang SCDN)

下述十四个技巧&#xff0c;是许多人在大量的数据库分析与设计实践中&#xff0c;逐步总结出来的。对于这些经验的运用&#xff0c;读者不能生帮硬套&#xff0c;死记硬背&#xff0c;而要消化理解&#xff0c;实事求是&#xff0c;灵活掌握。并逐步做到&#xff1a;在应用中发…

SpringBoot入门建站全系列(五)使用Spring-data-jpa操作数据库CRUD

SpringBoot入门建站全系列&#xff08;五&#xff09;使用Spring-data-jpa操作数据库 SpringBoot操作数据库有多种方式&#xff0c;如 JDBC直接操作:太古老了&#xff0c;没人愿意这样玩 Mybatis插件&#xff1a;比较时髦&#xff0c;比较适合sql复杂&#xff0c;或者对性能…

Spring和Netty整合详解

Spring和Netty整合详解 本篇主要介绍netty如何跟Spring配合&#xff0c;其实真的很没必要将netty和Spring牵扯在一起&#xff0c;我们完全可以用netty做出一个spring的&#xff1b;然而在《Spring环境下使用Netty写Socket和Http详解》一篇中&#xff0c;因为没怎么用到Spring&…

yield from (python生成器)

#生成器中的yield from是干什么用的&#xff08;一般多用于线程&#xff0c;协程那&#xff09;def func(): # for i in AB: # yield i yield from AB # 就相当于上面的for循环&#xff0c;把循环简化了&#xff08;后面跟可迭代对象&#xff09; g func()print(list(g))转载于…

Spring和Spring Mvc 5整合详解

Spring和Spring Mvc 5整合详解 一、官方主页 Spring Spring Mvc 低版本的SpringMvc&#xff0c;可以参考这一篇《Spring和Spring Mvc整合详解》 二、概述 Spring Mvc的启动方式不同于Spring Boot&#xff0c;Spring Boot内嵌了tomcat容器&#xff0c;可以打包成jar文件快…