R語言—連接Oracle數據庫


本教程會講解兩種方法,第一種方法較為簡單,且中文不容易出現亂碼。第二種方法,較為復雜,和java的jdbc連接數據庫操作類似。

 

操作環境:

      • 系統:windows10 64位
      • 數據庫:Oracle11g  用戶名:testuser  
      • 案例用表:emp
      • R語言版本:3.4.0  64位
      • RStudio版本:1.0.143

方法一(推薦):

1.設置"ODBC數據源(64位)"

圖1:控制面板>管理工具>ODBC數據源(64位)

圖2:有些設置,自己要記得,紅字中的代碼會用到。

 

2.代碼部分

> library(RODBC)  ##加載RODBC包,沒有成功的請先下載安裝install.packages("RODBC") > con<-odbcConnect("oracle",uid="testuser",pwd="testuser",believeNRows=FALSE) ##建立Oracle連接 > emp1<-sqlQuery(con,"select * from EMP") ##sqlQuery可帶查詢語句 > sqlFetch(con,'EMP')  ##sqlFetch可根據表名,獲取Oracle中的表(注意,這里表名在單引號中,雙引號會報錯) 
> odbcClose(con) ##關閉連接 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
1 7369 SMITH CLERK 7902 1980-12-17 800 NA 20 2 7499 ALLEN SALESMAN 7698 1981-02-20 1600 300 30 3 7521 WARD SALESMAN 7698 1981-02-22 1250 500 30
····

方法一結束!!!

 

方法二:

1.將驅動"ojdbc6_g.jar"放到R的工作空間中,不知道R工作空間的可以通過在RStudio中輸入"getwd()"查看路徑。

圖3:"ojdbc6_g.jar"文件在Oracle11g的目錄中能找到,無需下載

2.代碼部分

> library(RJDBC)  ##加載"RJDBC"包,如果失敗了。請安裝該包install.packages("RJDBC") > drv<-JDBC("oracle.jdbc.driver.OracleDriver","ojdbc6_g.jar", identifier.quote="\"")  ##java中JDBC的套路 > conn<-dbConnect(drv,"jdbc:oracle:thin:@127.0.0.1:1521:orcl","testuser","testuser") ##建立一個連接 > EMP<-dbReadTable(conn,'EMP') ##根據連接和表名獲取Oracle中的表 > table1<-dbGetQuery(conn,"select * from EMP")  ##根據sql記錄獲取Oracle中表的數據 > head(EMP,3)  ##查看前三行
 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO 1  7369 SMITH    CLERK 7902 1980-12-17 00:00:00  800   NA     20
2  7499 ALLEN SALESMAN 7698 1981-02-20 00:00:00 1600  300     30
3  7521  WARD SALESMAN 7698 1981-02-22 00:00:00 1250  500     30
> head(table1,3) ##查看前三行
 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO 1  7369 SMITH    CLERK 7902 1980-12-17 00:00:00  800   NA     20
2  7499 ALLEN SALESMAN 7698 1981-02-20 00:00:00 1600  300     30
3  7521  WARD SALESMAN 7698 1981-02-22 00:00:00 1250  500     30
> names(table1)=iconv(names(table1),"UTF-8","GBK")  ##若是表中列名為中文,讀取時出現亂碼,可用這句來搞定亂碼情況

方法二結束!!!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM