一、除了cx_Oracle,python還可以通過什么方式訪問Oracle數據庫
理論上,用其他任何方式(庫、語言)訪問Oracle的方式,你都可以用于Python中,這個神器叫做SWIG(http://www.swig.org/),它提供了C++Java/Python等諸多語言的互相調用的適配庫生成。Oracle本身自帶C/C++Java接口,你可以進行簡單封裝后,用SWIG包裝。這種重復造輪子的工作不建議采用,wx_Oracle是很簡單的方法。
或者通過jaydebeapi來實現。
核心代碼:
>>> 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()
簡單來說,目前幾乎所有的數據庫都是支持jdbc的,因此幾乎都能找到相應的jar包,通過jaydebeapi這個庫,只需要把jra放到指定的位置,然后在程序中使用它即可連接數據庫。
優點:
1.支持的數據庫種類多,只要有jar包就可以。
2.不需要關心過于程序的運行環境,只要是相同平臺下編譯出來的包,復制過來就可以直接運行。
缺點:
打包的時候需要連同jar包一起打,可能會導致安裝包過大。
延伸閱讀:
二、什么是數據庫
有組織且相互關聯的數據的集合稱為數據庫。database 是一個存儲數據的應用程序。它有各種應用程序,包括 MySQL、Microsoft SQL、Oracle 等。
每個數據庫都不同,因為每個公司/組織都有其結構、數據類型和約束。數據庫 會定期更新,以獲取有關公司的最新數據。
數據庫可以手動和數字方式維護。在這個數據無處不在的時代,數字數據庫是優選和使用。數據庫的大小取決于組織的數據和需求。