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 !
4 votes
mysqldump
est une commande distincte. Vous ne devriez pas être dansmysql
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
Voir stackoverflow.com/questions/17666249/
0 votes
J'ai vérifié les options mysql mais je n'ai pas trouvé de moyen d'exporter uniquement la structure et les données.
0 votes
@Samuel Liew Pourquoi cette question est-elle marquée comme étant dupliquée, j'ai posé cette question avant les questions ci-dessus, avez-vous vérifié la date de la question ?