MySQL을 SQLite로 변환
Windows에서 무료 툴을 사용하여 MySQL에서 SQLite로 변환할 수 있습니까?
mysql2sqlite가 있습니다.GitHub의 sh 스크립트
헤더에 기재되어 있듯이 스크립트는 다음과 같이 사용할 수 있습니다.
./mysql2sqlite.sh myDbase | sqlite3 database.sqlite
대체 수단
- 업데이트 버전 https://github.com/dumblob/mysql2sqlite
- MySQL 포럼에서 보다 간단한 스크립트가 게시되었습니다.
다음은 변환기 목록입니다.(오늘 아카이브 스냅숏)
Windows에서도 동작하지만 좀처럼 언급되지 않는 대체 방법은 특정 데이터베이스 차이를 추상화하는 ORM 클래스를 사용하는 것입니다.예를 들어 PHP(RedBean), Python(Django의 ORM 레이어, Storm, SqlAlchemy), Ruby On Rails(Active Record), 코코아(Data 등).
즉, 다음과 같이 할 수 있습니다.
- ORM 클래스를 사용하여 소스 데이터베이스에서 데이터를 로드합니다.
- 데이터를 메모리에 저장하거나 디스크에 일련화합니다.
- ORM 클래스를 사용하여 데이터를 대상 데이터베이스에 저장합니다.
Sequel(Ruby ORM)에는 데이터베이스 처리를 위한 명령줄 도구가 있습니다.루비가 설치되어 있어야 합니다.그 다음,
$ gem install sequel mysql2 sqlite3
$ sequel mysql2://user:password@host/database -C sqlite://db.sqlite
일부 DB 스키마를 변환할 수 없습니다.MySQL은 SQLite보다 복잡하고 기능이 풍부합니다.그러나 스키마가 단순하다면 SQL 파일로 덤프하여 가져오거나 SQLite DB로 로드할 수 있습니다.
약 이틀 전에 20GB 이상의 MySQL 데이터베이스를 SQLite로 변환해야 했을 때도 같은 문제에 직면했습니다.그것은 결코 쉬운 일이 아니었고 결국 나는 그 일을 하는 이 Python 패키지를 쓰게 되었다.
되어 있는 스크립트와는 ) 이며 Python을 사용하여 모든 할 수 입니다.pip install(Windows 서 。처리 중인 데이터의 생성기와 청킹을 사용하기 때문에 메모리 효율이 매우 높습니다.
또한 대부분의 데이터 유형을 MySQL에서 SQLite로 올바르게 번역하기 위해 약간의 노력을 기울였습니다.
이 툴은 Python 2.7 및 3.5+에서도 충분히 테스트되고 동작합니다.
명령줄을 통해 호출할 수 없지만 일부 대형 Python 오케스트레이션에 포함할 수 있는 표준 Python 클래스로도 사용할 수 있습니다.
사용 방법은 다음과 같습니다.
Usage: mysql2sqlite [OPTIONS]
Options:
-f, --sqlite-file PATH SQLite3 database file [required]
-d, --mysql-database TEXT MySQL database name [required]
-u, --mysql-user TEXT MySQL user [required]
-p, --mysql-password TEXT MySQL password
-h, --mysql-host TEXT MySQL host. Defaults to localhost.
-P, --mysql-port INTEGER MySQL port. Defaults to 3306.
-c, --chunk INTEGER Chunk reading/writing SQL records
-l, --log-file PATH Log file
-V, --vacuum Use the VACUUM command to rebuild the SQLite
database file, repacking it into a minimal amount
of disk space
--use-buffered-cursors Use MySQLCursorBuffered for reading the MySQL
database. This can be useful in situations where
multiple queries, with small result sets, need to
be combined or computed with each other.
--help Show this message and exit.
Sqlite는 공식적으로 변환 도구 목록을 가지고 있습니다.
http://www2.sqlite.org/cvstrac/wiki?p=ConverterTools
MySql DB를 SQLite로 변환하는 가장 간단한 방법:
1) MySql 데이터베이스용 SQL 덤프 파일을 생성합니다.
2) 여기에서 파일을 RebaseData 온라인 컨버터에 업로드합니다.
3) 다운로드 버튼이 페이지에 표시되어 데이터베이스를 Sqlite 형식으로 다운로드합니다.
먼저 이 스크립트가 필요합니다('mysql-to-sqlite.sh'이라는 파일에 넣습니다).
#!/bin/bash
if [ "x$1" == "x" ]; then
echo "Usage: $0 <dumpname>"
exit
fi
cat $1 |
grep -v ' KEY "' |
grep -v ' UNIQUE KEY "' |
grep -v ' PRIMARY KEY ' |
sed '/^SET/d' |
sed 's/ unsigned / /g' |
sed 's/ auto_increment/ primary key autoincrement/g' |
sed 's/ smallint([0-9]*) / integer /g' |
sed 's/ tinyint([0-9]*) / integer /g' |
sed 's/ int([0-9]*) / integer /g' |
sed 's/ character set [^ ]* / /g' |
sed 's/ enum([^)]*) / varchar(255) /g' |
sed 's/ on update [^,]*//g' |
sed 's/\\r\\n/\\n/g' |
sed 's/\\"/"/g' |
perl -e 'local $/;$_=<>;s/,\n\)/\n\)/gs;print "begin;\n";print;print "commit;\n"' |
perl -pe '
if (/^(INSERT.+?)\(/) {
$a=$1;
s/\\'\''/'\'\''/g;
s/\\n/\n/g;
s/\),\(/\);\n$a\(/g;
}
' > $1.sql
cat $1.sql | sqlite3 $1.db > $1.err
ERRORS=`cat $1.err | wc -l`
if [ $ERRORS == 0 ]; then
echo "Conversion completed without error. Output file: $1.db"
rm $1.sql
rm $1.err
else
echo "There were errors during conversion. Please review $1.err and $1.sql for details."
fi
그런 다음 데이터베이스 복사본을 덤프합니다.
you@prompt:~$ mysqldump -u root -p --compatible=ansi --skip-opt generator > dumpfile
이제 변환을 실행합니다.
you@prompt:~$ mysql-to-sqlite.sh dumpfile
모든 것이 정상적으로 진행되면 sqlite3에서 사용할 수 있는 dumpfile.db가 생성됩니다.
you@prompt:~$ sqlite3 dumpfile.db
SQLite version 3.6.10
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> .tables
dg_cities dg_forms dg_surnames
dg_counties dg_provinces dg_user_accounts
dg_countries dg_provinces_netherlands
dg_first_names dg_states
여러 가지 방법이 있습니다.저도 이런 문제가 있어서 많이 검색했더니 MySQL을 SQLite로 간단하게 변환할 수 있는 방법을 찾았어요.
다음의 순서에 따릅니다.
먼저 SQLite DB Browser를 설치해야 합니다(테이블 및 데이터 표시에 매우 작고 빠름).
메모장에서 MySQL 파일을 엽니다. 그렇지 않으면 메모장++에서 여는 것이 좋습니다.
첫 번째 추가 행이 포함된 정보 또는 쿼리를 제거하고 저장합니다.
SQLite DB Browser, Create Database, Tables 및 MySQL Database와 동일한 유형을 엽니다.
SQLite DB Browser의 메뉴바에서 File->을 선택하고 저장한 데이터 MySQL File을 Import합니다.
경고 후 SQLite 대화상자로 쉽게 변환됩니다.
오류가 발생한 경우 MySQL 파일에 추가 행이 있으면 추가 행을 삭제하십시오.
MySQL to SQLite Converter Software를 평가판으로 설치할 수도 있지만 변환을 위해 제공하는 정보는 수명입니다.
Mac을 실행하는 이 문제에 대한 저의 해결책은
- 루비와 후속편을 Macario의 답변과 유사하게 설치합니다.Mac OSX용 Ruby, mysql 및 sqlite3 Ruby on Rails 개발 설정을 돕기 위해 이 링크를 따라갔습니다.
속편 설치
$ gem install sequel그래도 필요한 경우
% gem install mysql sqlite3그런 다음 Sequel 문서 bin_sequel.rdoc을 기반으로 다음 문서를 사용했습니다(데이터베이스 복사 참조).
sequel -C mysql://myUserName:myPassword@host/databaseName sqlite://myConvertedDatabaseName.sqlite
Windows 사용자는 Windows 솔루션용 Ruby 및 Sequel을 설치할 수 있습니다.
이 실에 여러 가지 방법을 써봤지만 아무 소용이 없었어요.여기 새로운 솔루션이 있습니다.이 솔루션도 매우 간단합니다.
- RazorSQL을 설치합니다.Mac, Windows 및 Linux에서 작동합니다.
- 인레이저예를 들어 localhost에서 SQL을 데이터베이스에 연결합니다.sql 덤프 파일에서는 변환이 동작하지 않습니다.
- 데이터베이스 우클릭 -> 데이터베이스 변환 -> SQLite를 선택합니다.이렇게 하면 모든 txt 파일이 저장됩니다.
sqlite이 데이터베이스를 작성하기 위해 필요한 쿼리. - DB Browser for SQLite와 같은 SQLite 데이터베이스 관리자를 설치합니다.모든 OS에서 동작합니다.
- 빈 데이터베이스를 만들고 SQL 실행 탭으로 이동하여 3단계에서 내용을 붙여넣습니다.
이것으로 SQLite 데이터베이스를 사용할 수 있습니다.
Perl\Python\etc에서 간단한 스크립트를 작성하고 MySQL을 SQLite로 변환합니다.Mysql에서 데이터를 읽고 SQLite에 씁니다.
Jfly가 제안하는 SQLite2009 Pro Enterprise Manager가 마음에 듭니다.단,
MySQL 데이터 유형 INT는 SQLite 데이터 유형 INTEGER로 변환되지 않습니다(DBeaver와 함께 작동).
MySQL에서 외부 키 제약 조건을 가져오지 않습니다(MySQL에서 SQLite로 외부 키 제약 조건 전송을 지원하는 도구를 찾을 수 없습니다).
데이터베이스 파일이 제공되고 올바른 서버(SQLite 또는 MySQL)가 설치되지 않은 경우 다음 도구를 사용해 보십시오.https://dbconvert.com/sqlite/mysql/ 평가판에서는 각 테이블의 처음 50개 레코드를 변환할 수 있으며 나머지 데이터는 워터마크가 됩니다.이는 Windows 프로그램이며 실행 중인 데이터베이스 서버에 덤프하거나 출력을 .sql 파일로 덤프할 수 있습니다.
변환 도구 목록에서 Kexi를 찾았습니다.다양한 DB 서버(MySQL 포함)에서 SQLite로 가져오기 위한 UI 도구입니다.일부 데이터베이스를 Import할 때(예를 들어 MySQL에서) Kexi 형식으로 저장합니다.Kexi 형식은 '네이티브' SQLite 형식입니다.kexi 파일을 복사하고 데이터를 sqlite 형식으로 저장하기만 하면 됩니다.
언급URL : https://stackoverflow.com/questions/3890518/convert-mysql-to-sqlite
'programing' 카테고리의 다른 글
| MySQL/Maria에 대한 익명 읽기 전용 액세스DB (0) | 2023.01.26 |
|---|---|
| 어레이의 테트리스 설정 (0) | 2023.01.26 |
| Chrome에서 코드로부터 JavaScript 브레이크 포인트를 설정하는 방법 (0) | 2023.01.26 |
| pip은 TLS/SSL이 필요한 로케이션으로 설정되어 있지만 Python에서는 ssl 모듈을 사용할 수 없습니다. (0) | 2023.01.26 |
| 웅변 모델 이벤트에서 이전 속성 값 가져오기 (0) | 2023.01.16 |