Як експортувати базу даних mysql за допомогою командного рядка?


342

У мене база даних досить велика, тому я хочу експортувати її за допомогою командного рядка, але не знаю, як це зробити.

Я використовую WAMP.


6
DOS? ви використовуєте Windows 98? Або ти маєш на увазі командний рядок?
jle

Ви використовуєте wamp, ви також повинні мати phpmyadmin, з опцією експорту
Lars C. Magnusson

Відповіді:


537

Спочатку перевірте, чи ваш командний рядок розпізнає команду mysql. Якщо не перейти до команди та введіть:

set path=c:\wamp\bin\mysql\mysql5.1.36\bin

Потім скористайтеся цією командою для експорту вашої бази даних:

mysqldump -u YourUser -p YourDatabaseName > wantedsqlfile.sql

Потім вам буде запропоновано пароль бази даних .

Це експортує базу даних у шлях, який ви зараз перебуваєте, виконуючи цю команду

Примітка. Ось кілька детальних інструкцій щодо імпорту та експорту


7
це дає помилку "mysqldump: Отримала помилку: 1049: Невідома база даних" thepassword "при виборі бази даних", але працювала, коли я
видаляю

11
@ AteşDanış Немає місця між -pі thepassword.
Чарльз Вуд

44
Вам слід просто скористатися, -pі тоді буде запропоновано пароль. Таким чином , ви уникнути необхідності пароль збережений , наприклад , в.bash_history
Nuala

7
Для мене ця команда працює: mysqldump -u YourUser -p YourDatabaseName> wantsqlfile.sql (Введіть команду, натисніть клавішу enter, і тоді буде введений пароль).
шасі кант

3
Введення пароля в командному рядку слід вважати небезпечним.
веселий

112

Просто використовуйте таку команду,

Для експорту:

mysqldump -u [user] -p [db_name] | gzip > [filename_to_compress.sql.gz] 

Для імпорту:

gunzip < [compressed_filename.sql.gz]  | mysql -u [user] -p[password] [databasename] 

Примітка. Між ключовим словом '-p' та вашим паролем немає місця.


1
Я думаю, ви пропустили той факт, що він використовує WAMP - Windows ... gunzip / gzip не в комплекті з Windows. Можливо, запустіть свою команду після встановлення деяких речей, але я думаю, ви пропустили цей факт.
Рольф

2
Вказівка gzip -9робить отриманий файл трохи меншим, оскільки використовується максимальне стиснення.
АнтонК

39

Перш за все, відкритий командний рядок, а потім відкрити бін каталог у cmd (я сподіваюся, що ви знаєте з командами cmd ), перейдіть до каталогу бін папки MySql у програмних файлах WAMP .

запустити команду

mysqldump -u db_username -p database_name > path_where_to_save_sql_file

система натискання клавіші Enter експортує конкретну базу даних і створить файл sql у задане місце.

Я сподіваюся, що ви його отримали :) якщо у вас виникли запитання, будь ласка, дайте мені знати.


Мій друг, я намагався трохи пояснити процес. замість того, щоб дати пряму команду
Mitesh vaghela

38

Ну, ви можете використовувати команду нижче,

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

і згенерований файл буде доступний у тому самому каталозі, де ви виконали цю команду.

Ви можете знайти більше в офіційній довідці щодо mysqldump: Імпортувати експорт MySQL DB

Примітка : використовувати --databasesзамість--database що останній більше не підтримується.

Насолоджуйтесь :)


4
Для тих, хто отримує помилку на кшталт "Доступ заборонено при використанні БЛОКОВИХ ТАБЛИЦІВ", слід додати до команди параметр "--single-транзакція".
Skyrpex

Я отримав помилку, mysqldump: [ERROR] unknown option '--database'але дотепне виключення --databaseїї спрацювало.
hejdav

@Skyrpex Дякую, це було рішення, яке я шукав.
Martijn

22

Перейдіть до командного рядка на цьому шляху,

C:\Program Files (x86)\MySQL\MySQL Server 5.0\bin>

Потім дайте цю команду експортувати вашу базу даних ( немає місця після -p )

mysqldump -u[username] -p[userpassword] yourdatabase > [filepath]wantedsqlfile.sql


21

Знайдіть свій екземпляр mysql за допомогою:

which mysql

Якщо це правильно, експортуйте за допомогою наступного (інакше перейдіть до екземпляра mysql у папці mamp у біні):

mysqldump -u [username] -p [password] [dbname] > filename.sql

І якщо ви хочете застебнути його в той самий час:

mysqldump -u [username] -p [password] [db] | gzip > filename.sql.gz

Потім ви можете перемістити цей файл між серверами за допомогою:

scp user@xxx.xxx.xxx.xxx:/path_to_your_dump/filename.sql.gz your_detination_path/

(де xxx.xxx.xxx.xxx - IP-адреса сервера)

А потім імпортуйте його за допомогою:

gunzip filename.sql.gz | mysql -u [user] -p [password] [database]

4
Знову ж таки, W AMP => Windows. що є командою Linux. gunzip / gzip не постачаються в комплекті з Windows - і можуть бути недоступними. scp ... ви розумієте.
Рольф

Відповідь Opentuned чудова . Одна невелика річ - це видалення фактичного passwordз командного рядка: mysqldump -u [ім'я користувача] -p [dbname]> filename.sql Це заважає людям шукати пароль за вашою історією.
Вінсент

1
@Opentuned, Що з фетишем Linux?
Pacerier

for -p [pasword] повинен бути поруч, наприклад: mysqldump -u tutorials -p'mypassword' -h 127.0.0.1 database_name > file_backup_database_name_.sql Попередження: Використання пароля в інтерфейсі командного рядка може бути небезпечним.
Марван Салим

19

Щоб експортувати ПРОЦЕДУРИ, ФУНКЦІЇ та ТРІГЕРИ, також додайте --routinesпараметр:

mysqldump -u YourUser -p YourDatabaseName --routines > wantedsqlfile.sql


Перемикач --routinesмає різницю :) Будь-які підказки, як експортувати лише ПРОЦЕДУРИ, ФУНКЦІЇ І ТРІГЕРИ? Для тих, хто забув про комутатор та експортував "чисту" БД без "алгоритмів" :)
AntonK

BTW перемикач --eventsпотрібен для скидання подій планувальника подій, і TRIGGER завжди експортується, якщо --skip-triggersне зазначено (відповідно до 7.4.5.3 демпінгу збережених програм )
AntonK

10

Дайте цю команду експортувати вашу базу даних, сюди також буде включена дата

mysqldump -u[username] -p[userpassword] --databases yourdatabase | gzip > /home/pi/database_backup/database_`date '+%m-%d-%Y'`.sql.gz

(немає місця після -p)


Зауважте, що вказівка --databasesбуде вставляти оператори як CREATE DATABASE XYZ;і USE XYZ;, що не зручно при імпорті SQL в інший БД з іншим іменем ...
AntonK

8

Я встановив свій сервер wamp в D: диск, тому вам доведеться перейти до наступного шляху з командного рядка ур -> (а якщо ви встановили ур-wamp на c: диск, то просто замініть d: wtih c: тут)

D:\>cd wamp
D:\wamp>cd bin
D:\wamp\bin>cd mysql
D:\wamp\bin\mysql>cd mysql5.5.8 (whatever ur verserion will be displayed here use keyboard Tab button and select the currently working mysql version on your server if you have more than one mysql versions)
D:\wamp\bin\mysql\mysql5.5.8>cd bin
D:\wamp\bin\mysql\mysql5.5.8\bin>mysqldump -u root -p password db_name > "d:\backupfile.sql"

тут root є моїм паролем phpmyadmin - це пароль для phpmyadmin, тому якщо ви не встановили жодного пароля для root, просто нічого не введіть у цьому місці, db_name - це база даних (для якої ур. база даних займає резервну копію), backupfile.sql - це файл, у якому ви хочете створити резервну копію ур-бази даних, а ви також можете змінити розташування файлу резервної копії (d: \ backupfile.sql) з будь-якого іншого місця на вашому комп'ютері


З усіх способів, які я знайшов це зробити, ця відповідь є єдиним, який працював на мене. Я використовую MySQL версії 5.6, тому шлях був ... \ MySQL \ MySQL Server 5.6 \ bin для командного рядка. Вам доведеться використовувати своє ім’я та пароль адміністратора MySQL, ті, які визначені для певної бази даних, не працюватимуть. Дякую Сахін. Навіть інструкції в посібнику для MySQL для версії 5.6 не працюють. Синтаксис там неповний.
Макс Вест

Це дійсно працює з простором між -pі password?
Девіс

7
mysqldump -h [host] -p -u [user] [database name] > filename.sql

Приклад у localhost

mysqldump -h localhost -p -u root cookbook > cookbook.sql

4

Проблема з усіма цими рішеннями (використовуючи > символ переспрямовування) полягає в тому, що ви пишете свій дамп із stdout, що може порушити кодування деяких символів вашої бази даних.

Якщо у вас є проблема кодування символів. Як от :

ПОМИЛКА 1064 (42000): у вас є помилка у вашому синтаксисі SQL; перевірте посібник, який відповідає вашій версії сервера MySQL, чи правильний синтаксис для використання поруч ...

тоді ви ОБОВ'ЯЗКОВИ використовувати-r опцію для запису файла.

MySQL

mysqldump -u user -pyour-password-without-space-between-letter-p-and-your-password --default-character-set=utf8 --host $HOST database-name -r dump.sql

Використання Докера

docker exec --rm -v $pwd:dump -it mysql:5:7 mysqldump -u user -pyour-password-without-space-between-letter-p-and-your-password --default-character-set=utf8 --host $HOST database-name -r dump/dump.sql

Примітка. Це монтує поточний шлях як дамп всередині екземпляра.

Ми знайшли відповідь тут

І навпаки, не використовуйте <для імпорту дамп у вашу базу даних, знову ж таки, ваші символи non-utf8 можуть не передаватися; але віддайте перевагу вихідному варіанту.

mysql -u user -pYourPasswordYouNowKnowHow --default-character-set=utf8 your-database
mysql> SET names 'utf8'
mysql> SOURCE dump.sql

1

Синтаксис

(mysqldump.exe full path) -u (user name) -p (password) (database name) > (export database file full path)

Приклад

c:>d:\wamp\bin\mysql\mysql5.6.12\bin\mysqldump.exe -u root -p mydbname > d:\mydb.sql

де d: \ wamp \ bin \ mysql \ mysql5.6.12 \ bin \ mysqldump.exe буде вашим фактичним шляхом mysqldump.exe, mydbname - це ім'я бази даних, яку потрібно експортувати, а d: \ mydb.sql - шлях, куди ви хочете зберегти експортовану базу даних.


0

Я використовував сервер wamp. Я приміряв

c:\wamp\bin\mysql\mysql5.5.8\bin\mysqldump -uroot -p db_name > c:\somefolder\filename.sql

root це моє ім’я користувача для mysql, і якщо у вас є пароль, вкажіть його за допомогою:

-p[yourpassword]

Сподіваюся, це спрацює.


--password потрібно використовувати , якщо ви Трінг ввести пароль , а також
Ercé

0

Для ОС Windows :

Коли ви отримуєте помилку 1064 mysql (42000) при спробі виконання команди mysqldump , вийдіть з поточного терміналу. І виконати команду mysqldump.

mysql>exit 
c:\xampp\mysql\bin>mysqldump -uroot -p --databases [database_name] > name_for_export_db.sql

0

Я намагався взяти дамп db, який працював на докер, і придумав команду нижче, щоб досягти того ж:

docker exec <container_id/name>/ usr / bin / mysqldump -u <db_username>--password = <db_password> db_name> .sql

Сподіваюсь, це допомагає!


-2

Ви можете використовувати цей скрипт для експорту або імпорту будь-якої бази даних з терміналу, вказаного за цим посиланням: 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
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.