微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

通过数据库拆分具有多个数据库的mysqldump文件

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

马尼什

解决方法

这个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

原文地址:https://www.jb51.cc/mssql/81616.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐