macOS搭建Python的cx_Oracle開發(fā)環(huán)境

macOS搭建Python的cx_Oracle開發(fā)環(huán)境的過程總結(jié)缘厢。

環(huán)境與版本镊掖,

OS: macOS High Sierra 10.13.6

Oracle Instant Client: Version 12.2.0.1.0 (64-bit) Updated 15-Jan-2018

安裝Oracle Instant Client仇哆,

Oracle網(wǎng)站的下載需要注冊一個(gè)賬戶恤溶,根據(jù)macOS版本選擇Oracle Instant Client柏腻,自行申請下載冯挎。

https://www.oracle.com/technetwork/topics/intel-macsoft-096467.html

macOS版本 Oracle Instant Client版本
macOS High Sierra, Sierra and El Capitan Instant Client 12.2
macOS El Capitan, Yosemite and Mavericks Instant Client 12.1
macOS X Lion, Mountaint Lion and Mavericks Instant Client 11.2

下載所需要的文件杀饵,

basic: instantclient-basic-macos.x64-12.2.0.1.0-2.zip

sqlplus: instantclient-sqlplus-macos.x64-12.2.0.1.0-2.zip

sdk: instantclient-sdk-macos.x64-12.2.0.1.0-2.zip

解壓包到一個(gè)文件夾里莽囤,如/usr/local/lib/Oracle/instantclient_12_2

unzip instantclient-basic-macos.x64-12.2.0.1.0-2.zip # 提供基本功能
unzip instantclient-sqlplus-macos.x64-12.2.0.1.0-2.zip # 提供sqlplus命令行
unzip instantclient-sdk-macos.x64-12.2.0.1.0-2.zip # 提供頭文件切距,cx_Oracle會依賴其中的oci.h

鏈接庫文件朽缎,

添加到$HOME/lib/usr/local/lib的鏈接,以使應(yīng)用程序能夠找到庫谜悟。

ln -s /usr/local/lib/Oracle/instantclient_12_2/libclntsh.dylib.12.1 /usr/local/lib

如果您打算將可選的Oracle配置文件(如tnsnames.ora话肖,sqlnet.ora或oraaccess.xml)與Instant Client放在一起,則創(chuàng)建一個(gè)network/admin子目錄(如果該子目錄不存在)葡幸。

mkdir -p /usr/local/lib/Oracle/instantclient_12_2/network/admin

增加環(huán)境變量最筒,

export PATH=/usr/local/lib/Oracle/instantclient_12_2:$PATH # sqlplus工具也可以使用了

安裝cx_Oracle

pip install cx_Oracle

驗(yàn)證蔚叨,

>>> import cx_Oracle
>>> db = cx_Oracle.connect('hr', 'hrpwd', 'localhost:1521/XE')
>>> db1 = cx_Oracle.connect('hr/hrpwd@localhost:1521/XE')
>>> dsn_tns = cx_Oracle.makedsn('localhost', 1521, 'XE')
>>> print(dsn_tns)
(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521)))(CONNECT_DATA=(SID=XE)))
>>> db2 = cx_Oracle.connect('hr', 'hrpwd', dsn_tns)

參考文檔:

https://www.oracle.com/technetwork/topics/intel-macsoft-096467.html

https://oracle.github.io/odpi/doc/installation.html#macos

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末床蜘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蔑水,更是在濱河造成了極大的恐慌悄泥,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件肤粱,死亡現(xiàn)場離奇詭異弹囚,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)领曼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進(jìn)店門鸥鹉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人庶骄,你說我怎么就攤上這事毁渗。” “怎么了单刁?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵灸异,是天一觀的道長。 經(jīng)常有香客問我,道長肺樟,這世上最難降的妖魔是什么檐春? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮么伯,結(jié)果婚禮上疟暖,老公的妹妹穿的比我還像新娘。我一直安慰自己田柔,他們只是感情好俐巴,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著硬爆,像睡著了一般欣舵。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上缀磕,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天邻遏,我揣著相機(jī)與錄音,去河邊找鬼虐骑。 笑死准验,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的廷没。 我是一名探鬼主播糊饱,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼颠黎!你這毒婦竟也來了另锋?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤狭归,失蹤者是張志新(化名)和其女友劉穎夭坪,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體过椎,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡室梅,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了疚宇。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片亡鼠。...
    茶點(diǎn)故事閱讀 38,566評論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖敷待,靈堂內(nèi)的尸體忽然破棺而出间涵,到底是詐尸還是另有隱情,我是刑警寧澤榜揖,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布勾哩,位于F島的核電站抗蠢,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏思劳。R本人自食惡果不足惜迅矛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望敢艰。 院中可真熱鬧,春花似錦册赛、人聲如沸钠导。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽牡属。三九已至,卻和暖如春扼睬,著一層夾襖步出監(jiān)牢的瞬間逮栅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工窗宇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留措伐,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓军俊,卻偏偏與公主長得像侥加,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子粪躬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評論 2 348

推薦閱讀更多精彩內(nèi)容