2

在 OS X Mavericks上安装 RODBC/ROracle 包的后续行动...

首先,我使用@joran 提供的答案在 Mac OS 10.10.3 (Yosemite) 上安装了 ROracle。另外,使用启动 plist 文件设置 DYLD_LIBRARY_PATH,我可以运行library(ROracle),它加载得很好。但是,我无法使用 tnsnames.ora 文件连接到我的数据库。我已将 TNS_ADMIN 变量添加到 .Renviron 文件中,RStudio 似乎可以使用该文件:

> Sys.getenv("TNS_ADMIN")
[1] "opt/oracle/instantclient_11_2/network/admin"

例如,当我运行以下命令时

con <- dbConnect(drv = dbDriver("Oracle"), dbname = "db", username = "user", password = "pw")

,我得到错误

Error in .oci.Connect(.oci.drv(), username = username, password = password,  : 
  ORA-12154: TNS:could not resolve the connect identifier specified

此外,我还在 .bash_profile 中添加了 TNS_ADMIN 环境变量,但这并没有帮助。

注意 1:我已经使用 tnsnames.ora 文件通过 SQL Developer 连接到数据库,所以我相当确信问题出在文件内容之外。

注意 2:我实际上可以使用 ROracle 进行连接,例如:

# see example at http://www.oralytics.com/2015/05/loading-json-data-into-oracle-using.html
host <- "localhost"
port <- 1521
service <- "pdb12c"
drv <- dbDriver("Oracle")

connect.string <- paste(

"(DESCRIPTION=",

"(ADDRESS=(PROTOCOL=tcp)(HOST=", host, ")(PORT=", port, "))",

"(CONNECT_DATA=(SERVICE_NAME=", service, ")))", sep = "")

con <- dbConnect(drv, username = "dmuser", password = "dmuser", dbname = connect.string)

我仔细检查了我的 tnsnames.ora 文件,它的格式与 connect.string 完全相同,所以我认为 RStudio 实际上并没有看到它,尽管Sys.getenv("TNS_ADMIN")它给了我正确的路径。或者,可能是 Mac 上 dbname 参数所需的名称与 Windows 不同。

任何帮助将不胜感激!谢谢!

4

2 回答 2

0

我在网上看到了很多关于在 Yosemite 上添加环境变量以供 RStudio 访问的建议。至少到目前为止,唯一对我完全有效的方法是将所有环境变量添加到 plist 文件中。您可以根据需要添加任意数量的变量,@MortimorGoro 在通过 launchd.conf 设置环境变量中描述的变量不再适用于 OS X Yosemite/El Capitan/macOS Sierra?.

所以我在这里的解决方案是将 TNS_ADMIN 添加到 plist 中!

于 2015-08-10T11:22:54.993 回答
0

对于那些来到这里但使用 Windows 7 的人,在我的工作站上,我必须使用 TNSnames.ora 文件(也使用 TNS_ADMIN 环境变量)(位于:C:\app - 请参阅第二个屏幕截图),我得到以下信息去工作:

library(RODBC)

channel <- odbcConnect("PERMIT_DEV_odbc", uid = "POWDERED_TOAST_MAN", pwd = "dev_NONE_OF_YOUR_BEEZNEEZ", believeNRows = FALSE)

testsql <- "select sysdate from dual;"

query <- sqlQuery(channel = channel, query = testsql)

1 单击开始按钮(在 Windows 7 中)

2 开始输入“odbc”并查找“设置数据源 (ODBC)”或类似内容。

3 根据您的 TNS 文件添加您的连接。

4 还有一个“测试连接”按钮,您应该使用它来验证连接!

在此处输入图像描述

在此处输入图像描述

希望这可以帮助!

于 2018-02-20T22:13:21.550 回答