Heim > Datenbank > MySQL-Tutorial > Wie kann ich das Dumping von MySQL-Tabellen in separate Dateien automatisieren?

Wie kann ich das Dumping von MySQL-Tabellen in separate Dateien automatisieren?

Mary-Kate Olsen
Freigeben: 2024-10-27 04:46:02
Original
750 Leute haben es durchsucht

How Can I Automate Dumping MySQL Tables into Separate Files?

MySQL-Tabellen automatisch in separate Dateien sichern

Das integrierte Dienstprogramm mysqldump ermöglicht selektive Tabellen-Dumps, erfordert jedoch vorab festgelegte Tabellennamen . Für einen dynamischen Ansatz, der neue Tabellenzusätze verarbeitet, ist eine automatisierte Lösung erforderlich.

Eine solche Lösung ist ein Shell-Skript, das die Datenbank dynamisch nach allen Tabellennamen abfragt und jede Tabelle in einer separaten komprimierten Datei ablegt. Dadurch entfällt die Notwendigkeit einer manuellen Tabellennamenpflege im Dump-Skript.

Hier ist ein Beispielskript, das diese Funktionalität erreicht:

<code class="bash">#!/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 ) <DB_HOST> <DB_USER> <DB_NAME> [<DIR>]" && exit 1

DB_host=
DB_user=
DB=
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"</code>
Nach dem Login kopieren

Dieses Skript fordert zur Eingabe des Datenbankkennworts auf und fragt die angegebene Datenbank ab für Tabellennamen und speichert die Daten jeder Tabelle als SQL-Befehle in einzelnen komprimierten Dateien im angegebenen Verzeichnis (oder standardmäßig im aktuellen Arbeitsverzeichnis).

Das obige ist der detaillierte Inhalt vonWie kann ich das Dumping von MySQL-Tabellen in separate Dateien automatisieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage