MS Access * .MDB преобразование в MySQL или SQLite, проблема в кодировании данных - PullRequest
5 голосов
/ 20 мая 2011

Привет, я представлю свой случай:

  • Я в 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. некоторые дают разные результаты в данных, когда я их просматриваю, но все равно не имеют никакого смысла.

спасибо, и извините за мой плохой английский

1 Ответ

4 голосов
/ 21 мая 2011

Хорошо, тогда, поиграв во многих сайтах, я наткнулся на этот 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
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...