千家信息网

分割SQL文件

发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,小生博客:http://xsboke.blog.51cto.com -------谢谢您的参考,如有疑问,欢迎交流SQL备份需要导入到Mysql,
千家信息网最后更新 2025年02月02日分割SQL文件

小生博客:http://xsboke.blog.51cto.com

                            -------谢谢您的参考,如有疑问,欢迎交流

SQL备份需要导入到Mysql,但是SQL文件太大怎么办?

推荐一个shell脚本:mysqldumpsplitter

选项:

--source: mysqldump filename to process. It could be a compressed or regular file.--desc: This option will list out all databases and tables.--extract: Specify what to extract. Possible values DB, TABLE, ALLDBS, ALLTABLES, REGEXP--match_str: Specify match string for extract command option.--compression: gzip/pigz/bzip2/none (default: gzip). Extracted file will be of this compression.--decompression: gzip/pigz/bzip2/none (default: gzip). This will be used against input file.--output_dir: path to output dir. (default: ./out/)--config: path to config file. You may use --config option to specify the config file that includes following variables.    SOURCE=    EXTRACT=    COMPRESSION=    DECOMPRESSION=    OUTPUT_DIR=    MATCH_STR=

mysqldumpsplitter食谱:

从mysqldump中提取单个数据库:sh mysqldumpsplitter.sh --source filename --extract DB --match_str database-name上面的命令将从指定的"filename"sql文件为指定的数据库创建sql,并将其以压缩格式存储到database-name.sql.gz。从mysqldump中提取单个表:sh mysqldumpsplitter.sh --source filename --extract TABLE --match_str table-name上面的命令将从指定的"filename"mysqldump文件为指定的表创建sql,并将其以压缩格式存储到database-name.sql.gz。从mysqldump中提取与正则表达式匹配的表:sh mysqldumpsplitter.sh --source filename --extract REGEXP --match_str regular-expression上面的命令将为指定的"filename"mysqldump文件中的指定正则表达式的表创建sqls,并将其以压缩格式存储到单个table-name.sql.gz中。从mysqldump中提取所有数据库:sh mysqldumpsplitter.sh --source filename --extract ALLDBS上面的命令将从指定的"filename"mysqldump文件中提取所有数据库,并将其以压缩格式存储到单个database-name.sql.gz中。从mysqldump中提取所有表:sh mysqldumpsplitter.sh --source filename --extract ALLTABLES上面的命令将从指定的"filename"mysqldump文件中提取所有表,并将其以压缩格式存储到单个table-name.sql.gz中。从mysqldump中提取表的列表:sh mysqldumpsplitter.sh --source filename --extract REGEXP --match_str '(table1|table2|table3)'上面的命令将从指定的"filename"mysqldump文件中提取表,并将它们以压缩格式存储到单个table-name.sql.gz中。从压缩的mysqldump中提取数据库:sh mysqldumpsplitter.sh --source filename.sql.gz --extract DB --match_str 'dbname' --decompression gzip上面的命令将使用gzip解压缩filename.sql.gz,从"filename.sql.gz"中提取名为"dbname"的数据库并将其存储为out / dbname.sql.gz以压缩格式从压缩的mysqldump中提取数据库:sh mysqldumpsplitter.sh --source filename.sql.gz --extract DB --match_str 'dbname' --decompression gzip --compression none上面的命令将使用gzip解压缩filename.sql.gz并从"filename.sql.gz"中提取名为"dbname"的数据库并将其存储为plain sql out / dbname.sql从不同文件夹中的mysqldump中提取alltables:sh mysqldumpsplitter.sh --source filename --extract ALLTABLES --output_dir /path/to/extracts/上面的命令将从指定的"filename"mysqldump文件中提取所有表,并将压缩格式的表提取到存储在/ path / to / extracts /下的各个文件table-name.sql.gz。该脚本将创建文件夹/ p​​ath / to / extracts /如果不存在。从完整转储中的一个数据库中提取一个或多个表:考虑您有一个包含多个数据库的完整转储,并且您希望从一个数据库中提取少量表。Extract single database:`sh mysqldumpsplitter.sh --source filename --extract DB --match_str DBNAME --compression none`Extract all tables`sh mysqldumpsplitter.sh --source out/DBNAME.sql --extract REGEXP --match_str "(tbl1|tbl2)"`虽然我们可以使用另一个选项在单个命令中执行此操作,如下所示:sh mysqldumpsplitter.sh --source filename --extract DBTABLE --match_str "DBNAME.(tbl1|tbl2)" --compression none上面的命令将从当前目录中文件夹"out"下的sql格式的DBNAME数据库中提取tbl1和tbl2。您可以按如下方式提取单个表:sh mysqldumpsplitter.sh --source filename --extract DBTABLE --match_str "DBNAME.(tbl1)" --compression none从特定数据库中提取所有表:mysqldumpsplitter.sh --source filename --extract DBTABLE --match_str "DBNAME.*" --compression none上面的命令将以sql格式从DBNAME数据库中提取所有表,并将其存储在"out"目录下。列出mysqldump文件的内容mysqldumpsplitter.sh --source filename --desc上面的命令将列出转储文件中的数据库和表。
0