分割SQL文件
admin
2023-04-21 06:04:23
0

小生博客: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

上面的命令将列出转储文件中的数据库和表。

相关内容

热门资讯

燃气发电与电池储能相结合,成为... 来源:市场资讯 (来源:i商周) 孟菲斯一座xAI数据中心的燃气轮机 人工智能的用电飙升,让数据中心...
景嘉微:JM11性能大幅提升,... 有投资者在互动平台向景嘉微提问:“董秘您好!关注到近期有用户反馈公司JM11显卡推出了适配windo...
原创 v... 影像的发展进一步推动,不少品牌推出了专业影像手机,拥有2亿像素摄像头、色彩还原摄像头、影像芯片、影像...
荣耀首款自研耳夹式耳机官宣即将... 快科技5月13日消息,日前,荣耀首席营销官关海涛宣布,荣耀全场景团队自研首款耳夹式耳机马上上市,并称...
谷歌推出Googlebooks... IT之家 5 月 13 日消息,2026 年 I/O 开发者大会下周(5 月 19~20 日)召开之...
自控所推动GNC专业智能化升级 来源:滚动播报 (来源:中国航空报) 本报讯 5月6日,航空工业自控所召开 GNC+AI关键技术研发...
华电电力申请数据库访问方法专利... 国家知识产权局信息显示,华电电力科学研究院有限公司申请一项名为“数据库访问方法、装置、设备及介质”的...
苏州率先打造数据流通利用新范式 数据,作为第五大生产要素 具有流动性强、非消耗性、非均质性等特点 苏州率先打造数据流通利用新范式 夯...
伊媒披露伊美新一轮谈判5个先决... 当地时间5月12日,据伊朗法尔斯通讯社援引知情人士消息报道,伊朗对与美国新一轮谈判提出的5个先决条件...
英国将向霍尔木兹海峡多国护航行... 当地时间12日,总台记者从英国国防部获悉,英国将向在霍尔木兹海峡执行任务的多国护航行动提供无人机、战...