如何在linux下用R语言通过odbc访问oracle

如题所述

  一、下载安装包
  http //www unixodbc.org/
  下载文件:unixODBC-2.3.4.tar.gz
  Oracle ODBC Driver
  http //www oracle.com/technetwork/topics/linuxx86-64soft-092277.html
  (根据系统需求进oracle官网下载相应版本)
  下载文件:
  oracle-instantclient12.1-basic-12.1.0.2.0-1.x86_64.rpm
  oracle-instantclient12.1-devel-12.1.0.2.0-1.x86_64.rpm
  oracle-instantclient12.1-odbc-12.1.0.2.0-1.x86_64.rpm
  oracle-instantclient12.1-sqlplus-12.1.0.2.0-1.x86_64.rpm
  二、 安装
  1、 安装unixODBC
  以root的身份运行:
  tar –zxvf unixODBC-2.3.4.tar.gz
  cd unixODBC-2.3.4
  ./configure --prefix=/usr/local/unixODBC-2.3.4 --includedir=/usr/include --libdir=/usr/lib --bindir=/usr/bin --sysconfdir=/etc
  make
  make install
  安装成功后,unixODBC所需的头文件都被安装到了/usr/inlucde下,编译好的库文件安装到了/usr/lib下,与unixODBC相关的可执行文件安装到了/usr/bin下,配置文件放到了/etc下。
  2、 安装数据库ODBC驱动
  在ubuntu下用alien,在centos下用rpm安装oracle的四个包。
  进入oracle的安装目录(/usr/lib/x64/oracle/)
  chmod 775 odbc_update_ini.sh
  ./odbc_update_ini.sh /etc(没有提示表示安装成功)
  其中,odbc_update_ini.sh参数说明:
  参数1:unixODBC安装路径。
  参数2:驱动安装的绝对路径(可选)。
  默认为运行脚本的路径。
  参数3:驱动名(可选),默认为Oracle 11g ODBC driver。
  参数4:数据源名称(可选)。
  运行完成后将添加一个DNS条目到$HOME/.odbc.ini ,/etc/odbcinst.ini,名称为:OracleODBC-11g
  三、 设置环境变量
  export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/lib/x64/oracle/instantclient_11_2:/usr/local/lib
  PATH=$PATH:/usr/local/bin
  TNS_ADMIN(如果安装有oracle软件那么对应的就是$ORACLE_HOME/network/admin/目录,如果没有安装相应oracle软件,需要指定tnsnames.ora所在的目录,可选)
  NLS_LANG(设定合适的字符集,可选)
  LANG(系统字符编码,可选)
  /etc/profile (注意前面的英文句号,点号后面有空格) 将环境变量注册.
  一般来说,在centos里面你可以通过在/etc/ld.so.conf.d/目录下建一个新文件来实现
  文件的名字是xxxx.conf,比如oracleinstantclient.conf
  里面的内容就是目录:比如/usr/local/lib,可参考其他文件
  建好后,运行ldconfig,就可以把ld新配置装载进系统了
  四、 配置本地服务名(tnsnames.ora)
  按环境变量中TNS_ADMIN的设置目录,添加本地服务名:$TNS_ADMIN/tnsnames.ora或$ORACLE_HOME/network/admin/tnsnames.ora
  例如:TEST = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = xx.xx.xx.xx)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = test) ) )
  注:此处HOST为所连接的ip地址,PORT为端口号
  五、 检查驱动配置
  vi /etc/odbcinst.ini 在其中添加oracle驱动,如
  [Oracle 11g ODBC driver]
  Description = Oracle ODBC driver for Oracle 11g
  Driver = /root/instantclient_11_2/libsqora.so.10.1
  Setup =File
  Usage =
  CPTimeout =
  CPReuse =
  六、 添加oracle odbc配置(oracle用户)
  vi ~/.odbc.ini
  [OracleODBC-10g]
  Application Attributes = T
  Attributes = W
  BatchAutocommitMode = IfAllSuccessful
  BindAsFLOAT = F
  CloseCursor = F
  DisableDPM = F
  DisableMTS = T
  Driver = Oracle 11g ODBC driver #对应/usr/local/etc/odbcinst.ini中的驱动配置名称
  DSN = OracleODBC-11g
  EXECSchemaOpt =
  EXECSyntax = T
  Failover = T
  FailoverDelay = 10
  FailoverRetryCount = 10
  FetchBufferSize = 64000
  ForceWCHAR = F
  Lobs = T
  Longs = T
  MetadataId
  Default = F
  QueryTimeout = T
  ResultSets = T
  ServerName =TEST #对应tnsnames.ora中配置的本地服务名SQLGetData extensions = F
  Translation DLL =
  Translation ption = 0
  DisableRULEHint = T
  UserID =
  七、 测试
  用命令:isql<数据源名称> <用户名> <密码> -v
  [root@dwj~]$ isql OracleODBC-11g system oracle -v+---------------------------------------+|Connected! || ||sql-statement || help[tablename] ||quit || |+---------------------------------------+
温馨提示:答案为网友推荐,仅供参考