除了cx_Oracle,python還可以通過什么方式訪問Oracle數(shù)據(jù)庫?
一、除了cx_Oracle,python還可以通過什么方式訪問Oracle數(shù)據(jù)庫
理論上,用其他任何方式(庫、語言)訪問Oracle的方式,你都可以用于Python中,這個(gè)神器叫做SWIG(http://www.swig.org/),它提供了C++Java/Python等諸多語言的互相調(diào)用的適配庫生成。Oracle本身自帶C/C++Java接口,你可以進(jìn)行簡單封裝后,用SWIG包裝。這種重復(fù)造輪子的工作不建議采用,wx_Oracle是很簡單的方法。
或者通過jaydebeapi來實(shí)現(xiàn)。
核心代碼:
>>> import jaydebeapi
>>> conn = jaydebeapi.connect(“org.hsqldb.jdbcDriver”,
…?????????????????????????? “jdbc:hsqldb:mem:.”,
…?????????????????????????? [“SA”, “”],
…?????????????????????????? “/path/to/hsqldb.jar”,)
>>> curs = conn.cursor()
>>> curs.execute(‘create table CUSTOMER’
…????????????? ‘(“CUST_ID” INTEGER not null,’
…????????????? ‘ “NAME” VARCHAR(50) not null,’
…????????????? ‘ primary key (“CUST_ID”))’
…???????????? )
>>> curs.execute(“insert into CUSTOMER values (?, ?)”, (1, ‘John’))
>>> curs.execute(“select * from CUSTOMER”)
>>> curs.fetchall()
[(1, u’John’)]
>>> curs.close()
>>> conn.close()
簡單來說,目前幾乎所有的數(shù)據(jù)庫都是支持jdbc的,因此幾乎都能找到相應(yīng)的jar包,通過jaydebeapi這個(gè)庫,只需要把jra放到指定的位置,然后在程序中使用它即可連接數(shù)據(jù)庫。
優(yōu)點(diǎn):
1.支持的數(shù)據(jù)庫種類多,只要有jar包就可以。
2.不需要關(guān)心過于程序的運(yùn)行環(huán)境,只要是相同平臺(tái)下編譯出來的包,復(fù)制過來就可以直接運(yùn)行。
缺點(diǎn):
打包的時(shí)候需要連同jar包一起打,可能會(huì)導(dǎo)致安裝包過大。
延伸閱讀:
二、什么是數(shù)據(jù)庫
有組織且相互關(guān)聯(lián)的數(shù)據(jù)的集合稱為數(shù)據(jù)庫。database 是一個(gè)存儲(chǔ)數(shù)據(jù)的應(yīng)用程序。它有各種應(yīng)用程序,包括 MySQL、Microsoft SQL、Oracle 等。
每個(gè)數(shù)據(jù)庫都不同,因?yàn)槊總€(gè)公司/組織都有其結(jié)構(gòu)、數(shù)據(jù)類型和約束。數(shù)據(jù)庫 會(huì)定期更新,以獲取有關(guān)公司的最新數(shù)據(jù)。
數(shù)據(jù)庫可以手動(dòng)和數(shù)字方式維護(hù)。在這個(gè)數(shù)據(jù)無處不在的時(shí)代,數(shù)字?jǐn)?shù)據(jù)庫是優(yōu)選和使用。數(shù)據(jù)庫的大小取決于組織的數(shù)據(jù)和需求。

猜你喜歡LIKE
相關(guān)推薦HOT
更多>>
mysql怎么查看連接池是否已滿?
一、mysql怎么查看連接池是否已滿1.查看連接數(shù)配置(MySQL服務(wù)器允許的最大連接數(shù)16384)show variables like ‘%max_connections%’2.查看當(dāng)前...詳情>>
2023-10-17 21:20:19
什么是職場(chǎng)情商,如何提高?
什么是情商?情商是一個(gè) 20 世紀(jì) 90 年代作為學(xué)術(shù)話題出現(xiàn)的概念,并迅速成為商業(yè)心理學(xué)和職場(chǎng)動(dòng)態(tài)研究的重要組成部分。它通常被稱為 EQ(情商...詳情>>
2023-10-17 20:16:30
vector, list, map等容器使用場(chǎng)合是什么?
一、vector, list, map等容器使用場(chǎng)合vector適用于對(duì)象簡單,變化較小,并且頻繁隨機(jī)訪問的場(chǎng)景。list適用經(jīng)常進(jìn)行插入和刪除并且不經(jīng)常隨機(jī)訪...詳情>>
2023-10-17 19:45:03
數(shù)據(jù)挖掘中涉及的關(guān)聯(lián)規(guī)則在實(shí)際生活中的應(yīng)用有哪些?
一、數(shù)據(jù)挖掘中涉及的關(guān)聯(lián)規(guī)則在實(shí)際生活中的應(yīng)用關(guān)于關(guān)聯(lián)規(guī)則分析,這篇文章可以認(rèn)真學(xué)習(xí)一下,講的比較全面,關(guān)聯(lián)規(guī)則分析還在零售、快消、電...詳情>>
2023-10-17 18:40:06熱門推薦
sql server2012r2所在服務(wù)器做端口限制,需要開放什么端口才能繼續(xù)訪問數(shù)據(jù)庫?
沸Oracle有什么優(yōu)勢(shì)和劣勢(shì)?
熱數(shù)據(jù)庫聚集索引非聚集索引實(shí)現(xiàn)上有哪些區(qū)別?
熱數(shù)據(jù)庫(如oracle、mysql)及編程語言(php、python、perl、lisp)的區(qū)別?
新CSS 隱藏頁面元素有哪些方法?
除了cx_Oracle,python還可以通過什么方式訪問Oracle數(shù)據(jù)庫?
SQL開啟事務(wù)處理的語句 START TRANSACTION 和BEGIN TRAN的區(qū)別?
Android適配你需要學(xué)習(xí)哪些?
開發(fā)web應(yīng)用,好的開發(fā)流程是怎么樣的?
為什么說Gradle是Android進(jìn)階繞不去的坎?
mysql怎么查看連接池是否已滿?
WHERE中有很多IN判斷怎么提速?
軟件開發(fā)要遵循哪些事項(xiàng)?
有了innodb buffer pool為什么要有redis?
技術(shù)干貨







快速通道 更多>>
-
課程介紹
點(diǎn)擊獲取大綱 -
就業(yè)前景
查看就業(yè)薪資 -
學(xué)習(xí)費(fèi)用
了解課程價(jià)格 -
優(yōu)惠活動(dòng)
領(lǐng)取優(yōu)惠券 -
學(xué)習(xí)資源
領(lǐng)3000G教程 -
師資團(tuán)隊(duì)
了解師資團(tuán)隊(duì) -
實(shí)戰(zhàn)項(xiàng)目
獲取項(xiàng)目源碼 -
開班地區(qū)
查看來校路線