Mysql
 sql >> база данни >  >> RDS >> Mysql

Разделете mysqldump файл с множество бази данни по база данни

Този Perl скрипт трябва да свърши работа.

#!/usr/bin/perl -w
#
# splitmysqldump - split mysqldump file into per-database dump files.

use strict;
use warnings;

my $dbfile;
my $dbname = q{};
my $header = q{};

while (<>) {

    # Beginning of a new database section:
    # close currently open file and start a new one
    if (m/-- Current Database\: \`([-\w]+)\`/) {
    if (defined $dbfile && tell $dbfile != -1) {
        close $dbfile or die "Could not close file!"
    } 
    $dbname = $1;
    open $dbfile, ">>", "$1_dump.sql" or die "Could not create file!";
    print $dbfile $header;
    print "Writing file $1_dump.sql ...\n";
    }

    if (defined $dbfile && tell $dbfile != -1) {
    print $dbfile $_;
    }

    # Catch dump file header in the beginning
    # to be printed to each separate dump file.  
    if (! $dbname) { $header .= $_; }
}
close $dbfile or die "Could not close file!"

Изпълнете това за дъмп файла, съдържащ всички бази данни

./splitmysqldump < all_databases.sql


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. CodeIgniter/PHP/MySQL:Извличане на данни с JOIN

  2. За какво е jdbc драйверът org.gjt.mm.mysql.Driver?

  3. Какъв тип бихте съпоставили BigDecimal в Java/Hibernate в MySQL?

  4. Как мога да принудя да изляза всички потребители на уебсайт?

  5. MySQL връзка през SSL с Laravel