MySQL: comment exporter et importer un.fichier sql de la ligne de commande? [dupliquer]

cette question a déjà une réponse ici:

je veux exporter et importer A.fichier sql vers et à partir d'une base de données MySQL en ligne de commande.

Est-il une commande pour l'exportation .fichier sql dans MySQL? Alors comment puis-je importer?

lors de l'importation, il peut y avoir des contraintes comme enable/disable contrôle de clé étrangère ou structure de table export only .

peut-on mettre ces options avec mysqldump ?

259
demandé sur AZinkey 2012-07-10 09:51:16

8 réponses

tapez la commande suivante pour importer le fichier de données sql:

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

dans cet exemple, importer des données.fichier sql dans le "blog" de la base de données à l'aide de vivek comme nom d'utilisateur:

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

si vous avez un serveur de base de données dédié, remplacez localhost hostname par le nom réel du serveur ou l'adresse IP comme suit:

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

pour exporter une base de données, utilisez ce qui suit:

mysqldump -u username -p databasename > filename.sql

Note Les symboles < et > dans chaque cas.

39
répondu Frankline 2012-07-10 06:22:35

si vous utilisez déjà le shell SQL, vous pouvez utiliser la commande source pour importer des données:

use databasename;
source data.sql;
20
répondu David Kennedy 2015-01-04 18:05:43

Essayer

mysqldump databaseExample > file.sql
12
répondu Youcha 2012-07-10 05:58:14

mysqldump vide pas les événements de base de données, des déclencheurs et des routines, sauf si explicitement indiqué lors de dumping individuelle de bases de données;

mysqldump -uuser -p db_name --events --triggers --routines > db_name.sql
11
répondu PodTech.io 2016-03-11 13:32:27

vous pouvez utiliser la commande ci-dessous pour exporter,

mysqldump --base de données --user=root --password your_db_name > export_into_db.sql

et le fichier généré sera disponible dans le même répertoire où vous avez exécuté cette commande.

maintenant, connectez-vous à mysql en utilisant la commande,

mysql-u[nom d'utilisateur] - p

alors utilisez commande "source" avec le chemin du fichier.

vous pourriez trouver plus sur: Import Export MySQL DB

Enjoy:)

5
répondu Umesh Patil 2018-06-15 09:30:10

Dump une base de données entière dans un fichier:

mysqldump -u USERNAME -p password DATABASENAME > FILENAME.sql
4
répondu Buzz 2014-01-01 03:54:38

depuis que je n'ai pas assez de réputation pour commenter après le plus haut poste, donc j'ajoute ici.

utilisez '|' sur la plate-forme linux pour économiser de l'espace disque.

thx @Hariboo, ajouter des événements/triggers/routints paramètres

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

quelques questions/conseils:

erreur: ......n'existe pas en utilisant des tables de verrouillage

# --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 root@"%" identified by "Passwd";

erreur 2006 (HY000) sur la ligne 866: le serveur MySQL est parti mysqldump: Obtenu errno 32 à écrire

# 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

erreur 1419 (HY000) à la ligne 32730: vous n'avez pas le super privilège et la journalisation binaire est activée (vous pourrait voulez utiliser la variable log_bin_trust_fonction_creators moins sûre)

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

erreur 1227 (42000) à la ligne 138: Accès refusé; vous avez besoin(au moins un des) super privilège (s) pour cette opération mysqldump: Got errno 32 sur write

# add sed/awk to avoid some privilege issues

espérons que cette aide!

2
répondu Howard.TH 2017-09-27 02:53:50

vous pouvez utiliser ce "script 151920920" pour exporter ou importer n'importe quelle base de données à partir du terminal indiqué sur ce lien: 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
0
répondu Ridhwan Luthra 2016-10-24 21:20:18