在 linux 系統中連接 mdb 數據庫,直接連接的話,mdb 默認的驅動無法識別非 windows 的路徑, 所以不能使用常規的連接 方式
DRIVER={Microsoft Access Driver (*.mdb)};DBQ=c:\\dir\\file.mdb
安裝
這里我們需要借助一些庫來實現第三方的驅動
我們需要安裝這些包:mdbtools, unixODBC, libmdbodbc
如果是支持 deb 的系統中,如果不能找到 libmdbodbc ,將以下路徑加入到軟件源列表中
deb http://ftp.de.debian.org/debian squeeze main
更新源后即可可以安裝 libmdbodbc 了
配置
安裝了需要的包后,需要做一些配置,才能支持 libmdbodbc 的驅動
[MDBToolsODBC]
Description = MDB Tools ODBC
Driver = /usr/lib/libmdbodbc.so.0
Setup =
FileUsage =
CPTimeout =
CPReuse =
/etc/odbc.ini 或者 ~/.odbc.ini
Description = Microsoft Access Try DB
Driver = MDBToolsODBC
Database = /path/to/mdb/file/test.mdb
Servername = localhost
Username =
Password =
port = 5432
代碼
配置好數據源后,就可以用于任何支持 odbc 訪問的應用中了,這里以 pyodbc 為例
#-*- coding: utf-8 -*- import pyodbc conn = pyodbc.connect('DSN=test'); cursor = conn.cursor() cursor.execute('select * from "省"') for row in cursor.fetchall(): print row.Name
注:如果是操作名稱中文的表或者字段等,需要將其包含在雙引號中,不然會出錯,當然,將表名做成中文這么二的做法, 還是不推薦使用的啦
pyodbc 是個很不錯的庫,api 也很好用,不過對中文支持的并不好,它并沒有默認以 unicode 處理數據,所以對于中文相關的應用, 編碼問題無處不在,只得慢慢折騰了。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
