关闭

linux下R语言通过odbc访问oracle

标签: linuxodbcoracle 11gr语言
1728人阅读 评论(0) 收藏 举报
分类:

一、        下载

1、             unixODBC

http://www.unixodbc.org/

下载文件:unixODBC-2.3.0.tar.gz

2、             Oracle ODBC Driver

http://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html(根据系统需求进oracle官网下载相应版本)

下载文件:

instantclient-basic-linux-11.2.0.3.0.zip,instantclient-sqlplus-linux-11.2.0.3.0.zipinstantclient-odbc-linux-11.2.0.3.0.zip(ubuntu则可以用此zip包,redhat可以用相应的rpm安装)

将所有下载的文件上传至服务器的/root目录下(目录可以自定义,只要前后一致就可以了。也可以使用mv命令移动文件到自定义的位置上)

二、        安装

1、         安装unixODBC

以root的身份运行:

#tar –zxvf unixODBC-2.3.0.tar.gz

#cd unixODBC-2.3.0

#./configure  --prefix=/usr/local/unixODBC-2.3.0--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驱动

#cd /root
#unzip instantclient-basic-linux-11.2.0.3.0.zip

#unzip instantclient-sqlplus-linux-11.2.0.3.0.zip

#unzip instantclient-odbc-linux-11.2.0.3.0.zip
(3个文件解压到同一个目录instantclient_11_2下)
#cd  instantclient_11_2
#chmod 775 odbc_update_ini.sh
#./odbc_update_ini.sh /usr/local
(没有提示表示安装成功)

 

其中,odbc_update_ini.sh参数说明:
参数1:unixODBC DM安装路径。
参数2:驱动安装的绝对路径(可选)。默认为运行脚本的路径。
参数3:驱动名(可选),默认为Oracle 11g ODBC driver。
参数4:数据源名称(可选),默认为OracleODBC-11g。
运行完成后将添加一个DNS条目到$HOME/.odbc.ini ,<DriverManager_HOME>/etc/odbcinst.ini,名称为:OracleODBC-11g

修改odbc目录的权限:
chown –R 775 /opt/odbc

三、        设置环境变量

#export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/root/instantclient_11_2:/usr/local/libPATH=$PATH:/usr/local/bin TNS_ADMIN(如果安装有oracle软件那么对应的就是$ORACLE_HOME/network/admin/目录,如果没有安装相应oracle软件,需要指定tnsnames.ora所在的目录,可选) NLS_LANG(设定合适的字符集,可选) LANG(系统字符编码,可选)

# .  /etc/profile (注意前面的英文句号,点号后面有空格) 将环境变量注册.

四、        配置本地服务名(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           =
FileUsage       =
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
MetadataIdDefault = 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                                 |
|                                      |
+---------------------------------------+

八、        其他数据库

1、             对于mysql来说,如果是redhat,可直接rpm --ivh mysql-connector-odbc-5.1.6-0.i386.rpm;其他linux系统可下载相应的zip包,解压安装。

2、             对于SQLServer来说,需要额外的工具freetds-0.82.tar.gz。

 

当然,不管对于哪种数据库,仍然需要配置/.odbc.ini,/etc/odbcinst.ini和tnsnames.ora这三个文件。
0
0
查看评论

Linux下用unixODBC连接Oracle数据库的配置

用unixODBC连接Oracle数据库的配置
  • lichangzai
  • lichangzai
  • 2014-10-20 17:43
  • 7496

R语言连接Oracle的一种方式:使用ROacle

由于网上对于ROracle的安装不是最新的,所以贴出最新的额安装过程分享
  • chenchudongsg
  • chenchudongsg
  • 2016-11-16 17:27
  • 1120

R语言ORACLE数据库连接

library(RJDBC) drv           ojdbc6_g是oracle的驱动包,需要提前下载放到R当前目录下 conn 删除表: dbRemoveTable(conn,"zybi.test1") ...
  • scjthree
  • scjthree
  • 2014-10-10 17:36
  • 3528

odbc配置_oracle12_for_linux_x86_64

  • 2015-12-03 15:05
  • 58.49MB
  • 下载

Windows Oracle ODBC 安装配置

环境:Windows 7, 32 位操作系统 1.下载驱动包 Oracle 官网即可下载。 base包:instantclient-basic-win32-10.2.0.4.zip odbc包:instantclient-odbc-win32-10.2.0.4.zip 两个包的版本必须要一致。 2....
  • buxizhizhou530
  • buxizhizhou530
  • 2015-04-23 23:01
  • 2160

R通过 ODBC方式连接sql server

一、先配置好ODBC数据源 二、R中连接操作 1、加载包 > library(RODBC) 2、创建连接: > channel 3、查看某张表里的内容 > sqlQuery(channel,"select * fro...
  • longtingjing
  • longtingjing
  • 2015-09-20 11:17
  • 439

如何通过ROracle package通过r连接oracle数据库

最近由于需要通过oracle获取数据库数据,而本人也就会r语言所以一直在找方法。 由于本人对计算机系统方面知识浅薄,试遍了网上各种方法,总算亲测成功,分享给大家,希望帮助到有需要的人(其实主要还是自己老了记性不好,便于下次自己查看??)。 r语言连接oracle主要有三种方法,分别通过;RJDB...
  • tiaomie19870809
  • tiaomie19870809
  • 2018-02-01 23:44
  • 11

LINUX安装ODBC驱动

LINUX安装ODBC驱动
  • dongweizu33
  • dongweizu33
  • 2017-01-19 15:05
  • 2853

linux下oracle通过unixODBC连接MySQL

1-安装unixODBC     tar zxvf unixODBC-2.2.12.tar.gz(或者tar.tar)     cd unixODBC-2.2.12     ./configure --pref...
  • wolaiye320
  • wolaiye320
  • 2016-04-18 11:35
  • 355

C++通过ODBC连接Oracle数据库

ODBC的基本介绍 ODBC是为数据库应用程序访问关系型数据库时提供的一个统一的接口,对于不同的数据库ODBC提供了一套统一的API,使应用程序可以访问任何一种提供了ODBC驱动程序的数据库。但是ODBC只能用于关系型数据库,这就使得利用ODBC很难访问对象型数据库及其他非关系型数据库。 ...
  • ilikehigame
  • ilikehigame
  • 2014-09-09 15:54
  • 2294
    个人资料
    • 访问:161369次
    • 积分:2451
    • 等级:
    • 排名:第17778名
    • 原创:77篇
    • 转载:39篇
    • 译文:3篇
    • 评论:19条
    文章分类
    最新评论