Pas de doublon! à la recherche d'une fonctionnalité ayant phpmyadmin lors de l'exportation en ligne de commande
Je souhaite exporter et importer un fichier .sql vers et depuis une base de données MySQL à partir de la ligne de commande .
Existe-t-il une commande permettant d’exporter un fichier .sql dans MySQL? Alors comment puis-je l'importer?
Lors de l’exportation/importation, il peut exister des contraintes telles que activer/désactiver la vérification de la clé étrangère ou n'exporte que la structure de table .
Pouvons-nous définir ces options avec mysqldump
?
quelques exemples d'options
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, importez le fichier 'data.sql' dans la base de données 'blog' en utilisant 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 le nom d'hôte localhost par le nom du serveur ou l'adresse IP réelle, 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
Notez les symboles <
et >
dans chaque cas.
Si vous exécutez déjà SQL Shell, vous pouvez utiliser la commande source
pour importer des données:
use databasename;
source data.sql;
mysqldump ne dumpera pas les événements, déclencheurs et routines de base de données, sauf mention explicite lors du vidage de bases de données individuelles;
mysqldump -uuser -p db_name --events --triggers --routines > db_name.sql
Eh bien, vous pouvez utiliser la commande ci-dessous pour exporter,
mysqldump --database --user = root --password votre_nom_db> export_into_db.sql
et le fichier généré sera disponible dans le même répertoire que celui où vous avez exécuté cette commande.
Maintenant, connectez-vous à mysql en utilisant la commande,
mysql -u [nom d'utilisateur] -p
utilisez ensuite la commande "source" avec le chemin du fichier.
Essayer
mysqldump databaseExample > file.sql
Vider une base de données entière dans un fichier:
mysqldump -u USERNAME -p password DATABASENAME > FILENAME.sql
puisque je n'ai pas assez de réputation pour commenter après le post le plus élevé, j'ajoute donc ici.
utiliser '|' sur la plate-forme 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: ...... n'existe pas lorsque vous utilisez 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";
ERROR 2006 (HY000) à la ligne 866: le serveur MySQL a disparu mysqldump: vous avez obtenu le code d'erreur 32 sur l'écriture
# 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 privilège SUPER et la journalisation binaire est activée (vous peut-être souhaitez 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 (au moins un des) privilège (s) SUPER pour cette opération mysqldump: vous obtenez le code d'erreur 32 lors de l'écriture
# add sed/awk to avoid some privilege issues
espérons cette aide!
Vous pouvez utiliser ce script pour exporter ou importer toute base de données du terminal indiquée via 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