[筆記]--Ubuntu安裝Oracle Instant Client


一、安裝Oracle Instant Client

1、下載Oracle client,在這里下載,需要下載3個RPM的包;

2、安裝alien,和依賴包

$ sudo apt-get install alien
$ sudo apt-get install libaio1

3、使用alien吧rpm包轉換成deb包,並且安裝:

$ sudo alien -i oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm
$ sudo alien -i oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm
$ sudo alien -i oracle-instantclient11.2-sqlplus-11.2.0.4.0-1.x86_64.rpm

一般會安裝在/usr/lib/oracle/11.2/client64目錄下

4、設置環境變量:vim ~/.bashrc,在最后添加以下內容

export ORACLE_HOME=/usr/lib/oracle/11.2/client64
export LD_LIBRARY_PATH=/usr/lib/oracle/11.2/client64/lib
export TNS_ADMIN=/usr/lib/oracle/11.2/client64/network/admin
export PATH=$PATH:$ORACLE_HOME/bin

在Ubuntu11.10和14.04測試,就需要添加PATH=$PATH:$ORACLE_HOME/bin,如果注釋PATH變量則會提示沒有‘sqlplus’命令;網上也有人說不需要;

5、添加文件:sudo vim /etc/ld.so.conf.d/oracle.conf 並加入以下內容

/usr/lib/oracle/11.2/client64/lib/

然后執行命令

sudo ldconfig

6、重新打開終端,輸入sqlplus /nolog;就可以進SQL了

7、在/usr/lib/oracle/11.2/client64/目錄添加tnsnames.ora文件

cd /usr/lib/oracle/11.2/client64
sudo mkdir network
cd network
sudo mkdir admin
cd admin
sudo vim tnsnames.ora

在tnsnames.ora添加的內容,注意:內容不能少;

ORCL =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.88.71)(PORT = 1521))
    )   
    (CONNECT_DATA =
      (SERVICE_NAME = orcl)
    )   
  )

並修改權限:sudo chmod a+w *.ora

8、進人sqlplus不能使用上下鍵查看歷史命令,安裝rlwrap解決

$ sudo apt-get install rlwrap

在~/.bashrc中添加別名

alias sqlplus='rlwrap sqlplus'

重新打開終端,進人sqlplus則可以使用上下鍵了;

 

二、安裝cx_Oracle,可以使用Python鏈接數據庫

1、下載安裝cx_Oracle,在這里下載,注意對應的Python、Oracle client版本,我用的是:cx_Oracle-5.1.2-11g-py27-1.x86_64.rpm

2、解壓cx_Oracle-5.1.2-11g-py27-1.x86_64.rpm,並把cx_Oracle.so文件復制到python的目錄,這里為:/usr/local/lib/python2.7/dist-packages

3、測試鏈接

import cx_Oracle

conn = cx_Oracle.connect("system/dingjia@192.168.88.202:1521/orcl")
print conn.version
conn.close()

運行該腳本后,可以打印出Oracle的版本;

 

 

 

 

參考文檔:


免責聲明!

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



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