自动将 MySQL 表转储到单独的文件
内置 mysqldump 实用程序允许选择性表转储,但需要预先指定表名称。对于处理新表添加的动态方法,自动化解决方案是必要的。
这样的解决方案之一是 shell 脚本,它动态查询数据库中的所有表名并将每个表转储到单独的压缩文件中。这样就无需在转储脚本中手动维护表名。
这是实现此功能的示例脚本:
#!/bin/bash
# Descr: Dump MySQL table data into separate SQL files for a specified database.
# Usage: Run without args for usage info.
# Author: @Trutane
[ $# -lt 3 ] && echo "Usage: $(basename $0) <DB_HOST> <DB_USER> <DB_NAME> [<DIR>]" && exit 1
DB_host=$1
DB_user=$2
DB=$3
DIR=${4:-.}
[ -d $DIR ] || mkdir -p $DIR
echo -n "DB password: "
read -s DB_pass
tbl_count=0
for t in $(mysql -NBA -h $DB_host -u $DB_user -p$DB_pass -D $DB -e 'show tables')
do
echo "DUMPING TABLE: $DB.$t"
mysqldump -h $DB_host -u $DB_user -p$DB_pass $DB $t | gzip > "$DIR/$DB.$t.sql.gz"
tbl_count=$(( tbl_count 1 ))
done
echo "$tbl_count tables dumped from database '$DB' into dir=$DIR"
此脚本提示输入数据库密码,查询指定数据库的表名,并将每个表的数据作为 SQL 命令转储到单独的数据库中指定目录(默认为当前工作目录)内的压缩文件。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3