按数据库拆分包含多个数据库的mysqldump文件

Man*_*hah 17 mysql database backup mysqldump reload

我有一个多个数据库的mysqldump文件(5).其中一个数据库需要很长时间才能加载,有没有办法按数据库拆分mysqldump文件,或者只是告诉mysql只加载一个指定的数据库?

马尼什

Mat*_*tti 25

这个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!"
Run Code Online (Sandbox Code Playgroud)

对包含所有数据库的转储文件运行此命令

./splitmysqldump < all_databases.sql
Run Code Online (Sandbox Code Playgroud)


小智 14

或者,可以直接将每个数据库保存到单独的文件中...

#!/bin/bash
dblist=`mysql -u root -e "show databases" | sed -n '2,$ p'`
for db in $dblist; do
    mysqldump -u root $db | gzip --best > $db.sql.gz
done
Run Code Online (Sandbox Code Playgroud)

  • 对机器可解析输出使用`mysql --batch --skip-column-names`而不是`sed`.[(参考)](https://dev.mysql.com/doc/refman/5.0/en/mysql-command-options.html) (4认同)

Set*_*eth -1

“mysqldump 文件”只是一个充满 SQL 语句的文本文件。因此,您可以使用任何类型的文本编辑器来按照您认为合适的方式进行编辑。

首先进行更具选择性的转储(每个文件仅一个数据库等)可能会更好。如果您无权访问原始数据库,您也可以执行完整恢复,然后再次使用 mysqldump 为各个数据库创建转储。

如果你只是想要一个快速而肮脏的解决方案,快速谷歌搜索会产生对一些可能 也有用的工具的引用。