永发信息网

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

答案:2  悬赏:80  手机版
解决时间 2021-02-05 01:03
如何在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 || |+---------------------------------------+
全部回答
2:start r, switch to the location which contains the rodbc package and an enter the following r code: install.packages(packagename.tar.gz) 3:after the package installation you can create a channel: ch=odbcconnect("oracle2") 4:check the channel with odbcgetinfo(ch) 5:if the connection was successful, the console shows something like this: odbcgetinfo(ch) dbms_name dbms_ver driver_odbc_ver "oracle" "10.02.0010" "03.52" data_source_name driver_name driver_ver "oracle2" "sqora32.dll" "11.02.0001" odbc_ver server_name "03.52" "143.93.91.33:1521/xe"
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
摩托车怠速高低都有什么效果
已知 a=√2012 b=√2011,求3a(a+b)的值
产假基本工资是从生育险里面扣除吗
我这有个加密解压包,谁能帮我解压了啊?成功有
明眸善睐的意思是什么啊?知道的请说下!
融安县公安局交警大队车管所大良工作站在什么
液相色谱法有几种类型?它们的保留机理是什么
三星,金立,op手机哪个更好?
东芝32L2303C 请问,这款电视的音频输出接口
公使库本的意思是什么啊?知道的请说下!
腾宏大药房凤庆众康店在哪里啊,我有事要去这
在qq对话框上面出现qqlove的标志代表什么
上联 文曲星君再世斗转星移 下联 阿弥陀佛降
下列各项,不属气机失常的病机是A.气虚B.气滞
永发水果蔬菜超市在什么地方啊,我要过去处理
推荐资讯
姓乔的乔怎么写?
橙光游戏仙泣破解版百度云,要能玩的那种,骑
别人送的狗怎么才能养好?
江岸区武汉中国移动(花桥合作营业厅)哪位知道
姓吴依字旁名字有什么名字呢
笔记本怎么连上手机的网络,忘详细。是不是特
商城家庭宾馆地址在哪,我要去那里办事
艾尚美地址在哪,我要去那里办事
黑红糖50斤装多少钱啊?
从1-8八个数字中任意抽取3个数字,取平均数,
中山市建菱汽车贸易有限公司地址在哪,我要去
欧版三星s7中国能用吗
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?