mdb转换为mysql_MS Access * .MDB转换为MySQL或SQLite,数据编码问题

好吧,然后玩了很多网站后,我偶然发现了这个http://git.ojuba.org/cgit/thawab/tree/并找到了一个给我一个想法的脚本(这是bok2ki.py,如果有人好奇的话),我爱开源! :)

我将MDB_ICONV参数添加为“UTF-8”作为其值,并将MDB_JET3_CHARSET参数值更改为“cp1256”

实际上我真的不知道那些参数究竟是什么,但我猜MDB_JET3 CHARSET是定义字符集/编码/代码页(我真的不知道区别,我应该研究更多)和MDB_ICONV是定义的目标数据库的编码。那些只是我的假设。

那么这是我的新脚本:

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="cp1256" MDB_ICONV="UTF-8" mdb-export -R ";\n" -I "x.mdb" $i;

echo "END TRANSACTION;" ) | sqlite3 "x.db"; done

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值