首頁 > 資料庫 > mysql教程 > 如何自動將 MySQL 表格轉儲到單獨的檔案中?

如何自動將 MySQL 表格轉儲到單獨的檔案中?

DDD
發布: 2024-10-29 05:03:29
原創
779 人瀏覽過

How can I automate the process of dumping MySQL tables into separate files?

自動將MySQL 表轉儲到單獨的檔案中

手動將表轉儲到單獨的檔案中可能很乏味,尤其是當您擁有包含大量表的大型資料庫時。要自動化此流程並避免遺失新新增表的轉儲,您可以考慮多種方法。

自動化表轉儲

起點是一個腳本,可以迭代所有現有表並將它們轉儲到單獨的文件中。以下是一個使用mysqldump 命令來實現此目的的範例腳本:

<code class="bash">#!/bin/bash

# dump-tables-mysql.sh
# Descr: Dump MySQL table data into separate SQL files for a specified database.

[ $# -lt 3 ] && echo "Usage: $(basename ) <DB_HOST> <DB_USER> <DB_NAME> [<DIR>]" && exit 1

DB_host=
DB_user=
DB=
DIR=

[ -n "$DIR" ] || DIR=.
test -d $DIR || mkdir -p $DIR

echo -n "DB password: "
read -s DB_pass
echo
echo "Dumping tables into separate SQL command files for database '$DB' into dir=$DIR"

for t in $(mysql -NBA -h $DB_host -u $DB_user -p$DB_pass -D $DB -e 'show tables')
do
    echo -n "DUMPING TABLE: $DB.$t... "
    mysqldump -h $DB_host -u $DB_user -p$DB_pass $DB $t | gzip > $DIR/$DB.$t.sql.gz
    echo "done."
done

echo "Tables dumped from database '$DB' into dir=$DIR"</code>
登入後複製

此腳本將提示您輸入資料庫密碼,然後迭代指定資料庫中的所有表並將它們轉儲到壓縮的.sql .gz 中指定目錄(--DIR) 中的檔案。

其他轉儲選項

如果單獨使用 mysqldump 指令不足以滿足您的需求,您可以使用其他腳本語言來存取 MySQL 並自動執行轉儲程序。一些可以連接到MySQL 的流行語言有:

  • Python(使用mysql 函式庫)
  • Ruby(使用mysql2 gem)
  • PHP(使用mysqli(使用mysql2 gem)
PHP(使用mysqlisqli)擴充)

這些語言提供了對轉儲過程的更多控制,允許您自訂輸出格式、處理錯誤以及根據需要執行其他操作。

以上是如何自動將 MySQL 表格轉儲到單獨的檔案中?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板