it-swarm.com.de

Wie exportiere und importiere ich eine .sql-Datei von der Kommandozeile mit Optionen?

Nicht duplizieren! auf der Suche nach einer Funktion haben phpmyadmin während des Exports in der Befehlszeile

Ich möchte eine .sql-Datei von einer Befehlszeile in eine MySQL-Datenbank exportieren und aus dieser importieren.

Gibt es einen Befehl zum Exportieren einer .sql-Datei in MySQL? Wie importiere ich es dann?

Beim Exportieren/Importieren kann es zu Einschränkungen kommen , z. B. zum Aktivieren/Deaktivieren der Fremdschlüsselprüfung oder nur Tabellenstruktur exportieren .

Können wir diese Optionen mit mysqldump setzen?

ein Beispiel für Optionen

enter image description here

290
AZinkey

Geben Sie den folgenden Befehl ein, um die SQL-Datendatei zu importieren:

$ mysql -u username -p -h localhost DATA-BASE-NAME < data.sql

In diesem Beispiel importieren Sie die Datei 'data.sql' mit vivek als Benutzernamen in die 'blog'-Datenbank:

$ mysql -u vivek -p -h localhost blog < data.sql

Wenn Sie einen dedizierten Datenbankserver haben, ersetzen Sie den Hostnamen localhost durch den tatsächlichen Servernamen oder die IP-Adresse wie folgt:

$ mysql -u username -p -h 202.54.1.10 databasename < data.sql

Verwenden Sie zum Exportieren einer Datenbank Folgendes:

mysqldump -u username -p databasename > filename.sql

Beachten Sie jeweils die Symbole < und >.

75
Frankline

Wenn Sie die SQL-Shell bereits ausführen, können Sie den Befehl source zum Importieren von Daten verwenden:

use databasename;
source data.sql;
28
David Kennedy

mysqldump gibt keine Datenbankereignisse, -auslöser und -routinen aus, es sei denn, dies wird beim Sichern einzelner Datenbanken ausdrücklich angegeben.

mysqldump -uuser -p db_name --events --triggers --routines > db_name.sql
20
PodTech.io

Nun, Sie können den folgenden Befehl verwenden, um zu exportieren,

mysqldump --database --user = root --password your_db_name> export_into_db.sql

die generierte Datei befindet sich in dem Verzeichnis, in dem Sie diesen Befehl ausgeführt haben.

Melden Sie sich jetzt mit dem Befehl mysql an.

mysql -u [benutzername] -p

verwenden Sie dann den Befehl "source" mit dem Dateipfad.

15
Umesh Patil

Versuchen

mysqldump databaseExample > file.sql
15
Youcha

Eine komplette Datenbank in eine Datei sichern:

mysqldump -u USERNAME -p password DATABASENAME > FILENAME.sql
7
Buzz

da ich nicht genug ruf habe um nach dem höchsten post zu kommentieren, füge ich hier hinzu.

benutze '|' auf Linux-Plattform, um Speicherplatz zu sparen.

dank @Hariboo können Sie Ereignisse/Trigger/Routinenparameter hinzufügen

mysqldump -x -u [uname] -p[pass]  -C --databases db_name  --events --triggers --routines | sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/ '  | awk '{ if (index($0,"GTID_PURGED")) { getline; while (length($0) > 0) { getline; } } else { print $0 } }'  | grep -iv 'set @@' | trickle -u 10240 mysql -u username -p -h localhost DATA-BASE-NAME

einige Probleme/Tipps:

Fehler: ...... bei Verwendung von LOCK TABLES nicht vorhanden

# --lock-all-tables,-x , this parameter is to keep data consistency because some transaction may still be working like schedule.
# also you need check and confirm: grant all privileges on *.* to [email protected]"%" identified by "Passwd";

FEHLER 2006 (HY000) in Zeile 866: Der MySQL-Server ist verschwunden. Mysqldump: Habe Fehler 32 beim Schreiben

# set this values big enough on destination mysql server, like: max_allowed_packet=1024*1024*20
# use compress parameter '-C'
# use trickle to limit network bandwidth while write data to destination server

FEHLER 1419 (HY000) in Zeile 32730: Sie haben keine SUPER-Berechtigung und die binäre Protokollierung ist aktiviert (Sie könnten möchten die weniger sichere Variable log_bin_trust_function_creators verwenden).

# set SET GLOBAL log_bin_trust_function_creators = 1;
# or use super user import data

FEHLER 1227 (42000) in Zeile 138: Zugriff verweigert; Sie benötigen mindestens eines der SUPER-Privilegien für diese Operation mysqldump: Got errno 32 on write

# add sed/awk to avoid some privilege issues

ich hoffe das hilft!

4
Howard.TH

Mit diesem Skript können Sie jede Datenbank aus dem unter diesem Link angegebenen Terminal exportieren oder importieren : https://github.com/Ridhwanluthra/mysql_import_export_script/blob/master/ mysql_import_export_script.sh

echo -e "Welcome to the import/export database utility\n"
echo -e "the default location of mysqldump file is: /opt/lampp/bin/mysqldump\n"
echo -e "the default location of mysql file is: /opt/lampp/bin/mysql\n"
read -p 'Would like you like to change the default location [y/n]: ' location_change
read -p "Please enter your username: " u_name
read -p 'Would you like to import or export a database: [import/export]: ' action
echo

mysqldump_location=/opt/lampp/bin/mysqldump
mysql_location=/opt/lampp/bin/mysql

if [ "$action" == "export" ]; then
    if [ "$location_change" == "y" ]; then
        read -p 'Give the location of mysqldump that you want to use: ' mysqldump_location
        echo
    else
        echo -e "Using default location of mysqldump\n"
    fi
    read -p 'Give the name of database in which you would like to export: ' db_name
    read -p 'Give the complete path of the .sql file in which you would like to export the database: ' sql_file
    $mysqldump_location -u $u_name -p $db_name > $sql_file
Elif [ "$action" == "import" ]; then
    if [ "$location_change" == "y" ]; then
        read -p 'Give the location of mysql that you want to use: ' mysql_location
        echo
    else
        echo -e "Using default location of mysql\n"
    fi
    read -p 'Give the complete path of the .sql file you would like to import: ' sql_file
    read -p 'Give the name of database in which to import this file: ' db_name
    $mysql_location -u $u_name -p $db_name < $sql_file
else
    echo "please select a valid command"
fi
1
Ridhwan Luthra