354 votes

Comment exporter et importer un fichier .sql en ligne de commande avec des options ?

Pas de doublon ! Recherche d'une fonctionnalité pour phpmyadmin lors de l'exportation en ligne de commande.

Je veux exporter et importer un fichier .sql vers et depuis une base de données MySQL à partir d'un ordinateur. ligne de commande .

Existe-t-il une commande pour exporter un fichier .sql dans MySQL ? Ensuite, comment puis-je l'importer ?

Lors de l'exportation/importation, il peut y avoir contraintes comme activer/désactiver vérification des clés étrangères ou structure de la table d'exportation uniquement .

Pouvons-nous mettre ces options avec mysqldump ?

quelques exemples d'options

enter image description here

4 votes

mysqldump est une commande distincte. Vous ne devriez pas être dans mysql lors de son exécution. Il suffit de l'écrire devant l'invite de commande. Et le point-virgule sert à indiquer à l'invite mysql que la commande est terminée. Comme vous exécutez mysqldump en tant que programme sur le terminal, vous ne devez pas le terminer par un point-virgule.

0 votes

Merci à Ozair et à tous les autres. Y a-t-il un moyen de définir des attributs tels que la clé étrangère, la structure uniquement, les données uniquement ?

0 votes

20voto

Buzz Points 51

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

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

0 votes

Et comment pouvons-nous définir des contraintes comme activer/désactiver la vérification des clés étrangères ou exporter uniquement la structure de la table avec mysqldump.

17voto

Youcha Points 467

Essayez

mysqldump databaseExample > file.sql

8voto

Howard.TH Points 111

Puisque je n'ai pas assez de réputation pour commenter après le post le plus élevé, j'ajoute donc ici.

utilisez '|' sur la plateforme linux pour économiser de l'espace disque.

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

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

quelques problèmes/conseils :

Erreur : ......not exist quand on utilise LOCK TABLES

# --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) à la ligne 866 : Le serveur MySQL a disparu mysqldump : Got errno 32 on write

# 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

ERROR 1419 (HY000) at line 32730 : Vous n'avez pas le privilège SUPER et la journalisation binaire est activée (vous pourrait vous voulez utiliser la variable moins sûre log_bin_trust_function_creators)

# 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 (d'au moins un) des privilèges SUPER pour cette opération mysqldump : Got errno 32 on write

# add sed/awk to avoid some privilege issues

J'espère que cela vous aidera !

0 votes

J'ai rencontré l'ERROR 1227 (42000). Je ne suis pas sûr de ce que vous vouliez dire par ajouter sed/awk.

3voto

Ridhwan Luthra Points 101

Vous pouvez utiliser ce script à 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

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X