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

如何在linux下用R语言通过odbc访问oracle,第1张

一、下载安装

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

是在编译/链接阶段报的错吧,需要包含odbc头文件或者链接odbc库。

具体方法:

1. 如果是编译时出错,请加上编译选项: -I${ODBC_INC}

2. 如果是链接时出错,请加上链接选项:-L${ODBC_LIB} -lldbc

上面的ODBC_INC、ODBC_LIB需要事先定义,与编译环境保持一致即可。

例如:sqlplus

username/password@servicename

于是想,用我的两台电脑双机互联试一试,也玩个远程连接。实验如下:

首先在我的台式机上安装了Oracle9i的数据库管理系统,并建立了一个数据库实例:xy然后为该实例新增了一个用户,用户名和密码都是kxy01

。启动实例xy后,在台式机上,直接在cmd环境键入:sqlplus kxy01/kxy01@xy

就可以连接上数据库,呵呵,想来本地连接都是不费吹灰之力就行的。

之后,在我的笔记本上安装了Oracle9i的Client工具。然后试着直接用上述命令访问,显然是不行的,系统返回无法解析服务名的错误信息。

要实现连接到远程数据库,先了解一下相关知识吧,查了一下书。原来,

Net Configuration Assitant

的工具,应该就是它了。启动之:

Net Configuration Assitant共提供了4个配置功能:

监听程序配置,

命名方法配置,

本地网络服务名配置

目录使用配置。

要从远程位置连接Oracle数据库,必须配置Oracle网络监听程序。

Net Configuration Assitant

可以用于此项配置工作,启动后选择监听程序配置,一路下一步即可。

之后点开命名方法配置,系统已经默认提供了三种,其他两种也不太认识,干脆不改了,直接点后退,回到主菜单。

主菜单中,第三项是本地网络服务名配置。要通过网络访问Oracle数据库或其他服务,要使用网络服务名,该项配置允许使用由本地命名解析的网络服务名。而第四项为目录使用配置,点开一看,居然要选择目录服务器,我这一共就两台电脑,要什么目录服务,看来第四项不适合本实验了,显然,关键配置就在第三项:本地网络服务名配置。

将其点开,选择添加网络服务名 *** 作,然后会询问你希望访问何种版本的Oracle数据库服务。

按照常理,我装的是Oracle9i自然应该选择第一个(Oracle8i或更高版本数据库服务),可经过实践证明,只有选择第二个(Oracle8i发行版8.0数据库或服务)才能正常实现远程连接,不明其中原因,也就只有选第二个拉。

然后输入我的数据库实例SID:xy然后选择网络协议,双机互联应该选择TCP吧,再然后填写数据库所在的主机名:kxyhome

。端口号采用默认的1521。

点击下一步,进行数据库连接的测试,测试成功后进行网络服务名的填写,这个名字就应该是sqlplus连接时候用的服务名了,这里我们使用:xyhome之后一切配置完成,来到命行,使用sqlplus进行连接:sqlplus kxy01/kxy01@xyhome成功啦!


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/8469021.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-16
下一篇2023-04-16

发表评论

登录后才能评论

评论列表(0条)

    保存