您好,我将介绍我的情况:
- 我在 linux ubuntu
- 我有几个 Jet3 .MDB(MS Acess 数据库),每个大约 500MB,其中的数据以 cp1256/WINDOWS-1256 编码
- 我已经按照这篇文章制作了 sqlite 数据库来进行转换http://cltb.ojuba.org/en/articles/mdb2sqlite。
这是我为转换数据库而制作的 bash 脚本。假设我有 MS Access x.MDB
mdb-schema "x.mdb" | perl -wpe 's%^DROP TABLE %DROP TABLE IF EXISTS %i;
s%(Memo/Hyperlink|DateTime( \(Short\))?)%TEXT%i;
s%(Boolean|Byte|Byte|Numeric|Replication ID|(\w+ )?Integer)%INTEGER%i;
s%(BINARY|OLE|Unknown ([0-9a-fx]+)?)%BLOB%i;
s%\s*\(\d+\)\s*(,?[ \t]*)$%${1}%;' | sqlite3 > x.db
for i in $(mdb-tables "x.mdb"); do echo $i; (
echo "BEGIN TRANSACTION;";
MDB_JET3_CHARSET="WINDOWS-1256" mdb-export -R ";\n" -I "x.mdb" $i;
echo "END TRANSACTION;" ) | sqlite3 "x.db"; done
我尝试将 MDB_JET3_CHARSET 更改为 WINDOWS-1256、cp1256、WINDOWS-1251、cp1251、UTF-8。当我浏览它时,有些会在数据中产生不同的结果,但仍然毫无意义。
之前谢谢,对不起我的英语不好