自動將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"
此腳本提示輸入資料庫密碼,查詢指定資料庫的表名,並將每個表的資料轉儲到單獨的資料庫中指定目錄(預設為目前工作目錄)內的壓縮檔案。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3