您的位置:首页 > 数据库 > Oracle

linux下R语言通过odbc访问oracle

2014-09-22 15:20 246 查看
一、        下载

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这三个文件。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: