>데이터 베이스 >MySQL 튜토리얼 >SQLite3 데이터베이스를 MySQL로 쉽게 마이그레이션하려면 어떻게 해야 합니까?

SQLite3 데이터베이스를 MySQL로 쉽게 마이그레이션하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-08 22:45:12934검색

How Can I Easily Migrate My SQLite3 Database to MySQL?

SQLite3에서 MySQL로 빠르고 쉬운 마이그레이션

SQLite3 데이터베이스를 MySQL로 마이그레이션하기 위한 간단한 접근 방식을 찾고 있다면 그렇지 않습니다. 홀로. 데이터를 수동으로 변환하려고 하면 가져온 데이터의 정확성이 불확실해지는 경우가 많습니다. 이 특정 변환을 위해 확립된 라이브러리는 없지만 두 파일 형식 간의 차이점을 기반으로 지침을 제공할 수 있습니다.

구문 차이점

  • SQLite3은 MySQL에서는 "BEGIN TRANSACTION" 및 "COMMIT"이 생략됩니다.
  • MySQL에서는 대신 큰따옴표가 필요합니다.
  • MySQL은 SQLite3의 큰따옴표와 달리 "INSERT INTO" 절의 문자열에 작은따옴표를 사용합니다.
  • 이스케이프 문자열은 두 시스템마다 다릅니다.
  • MySQL은 부울에 1과 0을 사용하는 반면 SQLite3은 't'와 0을 사용합니다. 'f.'
  • 자동 증가 기능의 이름은 SQLite3에서는 "AUTOINCREMENT"이고 MySQL에서는 "AUTO_INCREMENT"입니다.

데이터 마이그레이션을 위한 Perl 스크립트

저희는 이러한 차이점을 해결하고 특정 환경에서 성공적으로 테스트된 수정된 Perl 스크립트를 제공합니다. 데이터 세트. 하지만 특정 데이터에 맞게 맞춤설정해야 할 수도 있습니다.

#! /usr/bin/perl

while ($line = <>){
    if (($line !~  /BEGIN TRANSACTION/) &amp;&amp; ($line !~ /COMMIT/) &amp;&amp; ($line !~ /sqlite_sequence/) &amp;&amp; ($line !~ /CREATE UNIQUE INDEX/)){
        
        if ($line =~ /CREATE TABLE \&quot;([a-z_]*)\&quot;(.*)/i){
            $name = ;
            $sub = ;
            $sub =~ s/\&quot;//g;
            $line = &quot;DROP TABLE IF EXISTS $name;\nCREATE TABLE IF NOT EXISTS $name$sub\n&quot;;
        }
        elsif ($line =~ /INSERT INTO \&quot;([a-z_]*)\&quot;(.*)/i){
            $line = &quot;INSERT INTO \n&quot;;
            $line =~ s/\&quot;/\\&quot;/g;
            $line =~ s/\&quot;/\'/g;
        }else{
            $line =~ s/\'\'/\\'/g;
        }
        $line =~ s/([^\'])\'t\'(.)/THIS_IS_TRUE/g;
        $line =~ s/THIS_IS_TRUE/1/g;
        $line =~ s/([^\'])\'f\'(.)/THIS_IS_FALSE/g;
        $line =~ s/THIS_IS_FALSE/0/g;
        $line =~ s/AUTOINCREMENT/AUTO_INCREMENT/g;
        print $line;
    }
}

위 내용은 SQLite3 데이터베이스를 MySQL로 쉽게 마이그레이션하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.