выдает ошибку «mysqldump: ошибка: 1049: неизвестный пароль базы данных при выборе базы данных», но работает, когда я удаляю «-p пароль пользователя»
Ateş Danış
11
@ AteşDanış Там нет места между -pи thepassword.
Чарльз Вуд
44
Вы должны просто использовать, -pа затем вам будет предложено ввести пароль. Таким образом вы избегаете сохранения своего пароля, например, в.bash_history
nuala
7
Для меня эта команда работает: mysqldump -u YourUser -p YourDatabaseName> wantedsqlfile.sql (введите команду, нажмите enter, после чего будет введен пароль).
Шаси Кант
3
Указание пароля в командной строке следует считать небезопасным.
Я думаю, что вы упустили тот факт, что он использует WAMP - Windows ... gunzip / gzip не входят в комплект Windows. Возможно, вы запустите команду после установки какого-то материала, но я думаю, что вы упустили этот факт.
Рольф
2
Указание gzip -9делает результирующий файл немного меньше, потому что используется максимальное сжатие.
AntonK
39
Прежде всего, откройте командную строку, затем откройте каталог bin в cmd (надеюсь, вы знакомы с командами cmd ), перейдите в каталог bin вашей папки MySql в программных файлах WAMP .
Опять же W AMP => Windows. которая является командой Linux. gunzip / gzip не входят в комплект Windows и могут быть недоступны. scp ... ты понял.
Рольф
Ответ Opentuned великолепен . Одна небольшая вещь - это удаление фактического passwordиз командной строки: mysqldump -u [имя пользователя] -p [имя_базы]> имя_файла.sql Это не позволяет людям искать в вашей истории пароль.
Винсент
1
@ Открыто, что с фетишем Linux?
Пейсер
for -p [pasword] должен быть рядом, например: mysqldump -u tutorials -p'mypassword' -h 127.0.0.1 database_name > file_backup_database_name_.sqlПредупреждение: использование пароля в интерфейсе командной строки может быть небезопасным.
Марван Салим
19
Чтобы экспортировать ПРОЦЕДУРЫ, ФУНКЦИИ и ТРИГГЕРЫ, добавьте --routinesпараметр:
Переключатель --routinesимеет значение :) Любые советы, как экспортировать только ПРОЦЕДУРЫ, ФУНКЦИИ И ТРИГГЕРЫ? Для тех, кто забыл про коммутатор и экспортировал «чистые» БД без «алгоритмов» :)
AntonK
Кстати, коммутатор --eventsнеобходим для выгрузки событий планировщика событий, а TRIGGER всегда экспортируются, если --skip-triggersне указано иное (в соответствии с 7.4.5.3 Сброс хранимых программ )
AntonK
10
Дайте эту команду для экспорта вашей базы данных, она также будет включать дату
Обратите внимание, что указание --databasesбудет вставлять операторы как CREATE DATABASE XYZ;и USE XYZ;, что не удобно при импорте SQL в другую БД с другим именем ...
AntonK
8
Я установил свой wamp-сервер на диск D:, поэтому вам нужно перейти по следующему пути из командной строки ur -> (а если вы установили ur 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 andselect 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 для v.5.6 не работают. Синтаксис там неполный.
Макс Вест
Это действительно работает с пробелом между -pи password?
Проблема со всеми этими решениями (с использованием >символа перенаправителя) заключается в том, что вы пишете свой дамп из 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
И наоборот, не используйте <для импорта вашего дампа в вашу базу данных, опять же, ваши символы не-utf8 могут не передаваться; но предпочитаю исходный вариант.
mysql -u user -pYourPasswordYouNowKnowHow --default-character-set=utf8 your-database
mysql> SET names 'utf8'
mysql> SOURCE dump.sql
где d: \ wamp \ bin \ mysql \ mysql5.6.12 \ bin \ mysqldump.exe будет вашим фактическим путем mysqldump.exe, mydbname - это имя базы данных, которую вы хотите экспортировать, а d: \ mydb.sql - это путь, где Вы хотите сохранить экспортированную базу данных.
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"];thenif["$location_change"=="y"];thenread-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"];thenif["$location_change"=="y"];thenread-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
Ответы:
Сначала проверьте, распознает ли ваша командная строка команду mysql. Если нет, перейдите в команду и введите:
Затем используйте эту команду для экспорта вашей базы данных:
Затем вам будет предложено ввести пароль базы данных .
Это экспортирует базу данных по пути, в котором вы находитесь в данный момент, при выполнении этой команды
Примечание. Вот несколько подробных инструкций, касающихся как импорта, так и экспорта.
источник
-p
иthepassword
.-p
а затем вам будет предложено ввести пароль. Таким образом вы избегаете сохранения своего пароля, например, в.bash_history
Просто используйте следующую команду,
Для экспорта:
Для импорта:
Примечание. Между ключевым словом '-p' и вашим паролем нет пробела.
источник
gzip -9
делает результирующий файл немного меньше, потому что используется максимальное сжатие.Прежде всего, откройте командную строку, затем откройте каталог bin в cmd (надеюсь, вы знакомы с командами cmd ), перейдите в каталог bin вашей папки MySql в программных файлах WAMP .
Команда выполнения
нажмите enter, система экспортирует конкретную базу данных и создаст файл sql в указанное место.
Я надеюсь, что вы поняли :) Если у вас есть какие-либо вопросы, пожалуйста, дайте мне знать.
источник
Ну, вы можете использовать приведенную ниже команду,
mysqldump --databases --user=root --password your_db_name > export_into_db.sql
и сгенерированный файл будет доступен в том же каталоге, где вы выполнили эту команду.
Вы можете найти больше на официальной ссылке
mysqldump
: Импорт Экспорт MySQL DBПримечание : используйте
--databases
вместо,--database
так как последний больше не поддерживается.Наслаждаться :)
источник
mysqldump: [ERROR] unknown option '--database'
но остроумие исключения--database
сработало.Перейдите в командную строку по этому пути,
C:\Program Files (x86)\MySQL\MySQL Server 5.0\bin>
Затем дайте эту команду для экспорта вашей базы данных ( без пробела после -p )
mysqldump -u[username] -p[userpassword] yourdatabase > [filepath]wantedsqlfile.sql
источник
Найдите свой экземпляр mysql с помощью:
Если это правильно, экспортируйте с помощью следующего (иначе перейдите к экземпляру mysql в папке mamp в bin):
И если вы хотите заархивировать его одновременно:
Затем вы можете переместить этот файл между серверами с помощью:
(где xxx.xxx.xxx.xxx - IP-адрес сервера)
И затем импортируйте это с:
источник
password
из командной строки: mysqldump -u [имя пользователя] -p [имя_базы]> имя_файла.sql Это не позволяет людям искать в вашей истории пароль.mysqldump -u tutorials -p'mypassword' -h 127.0.0.1 database_name > file_backup_database_name_.sql
Предупреждение: использование пароля в интерфейсе командной строки может быть небезопасным.Чтобы экспортировать ПРОЦЕДУРЫ, ФУНКЦИИ и ТРИГГЕРЫ, добавьте
--routines
параметр:mysqldump -u YourUser -p YourDatabaseName --routines > wantedsqlfile.sql
источник
--routines
имеет значение :) Любые советы, как экспортировать только ПРОЦЕДУРЫ, ФУНКЦИИ И ТРИГГЕРЫ? Для тех, кто забыл про коммутатор и экспортировал «чистые» БД без «алгоритмов» :)--events
необходим для выгрузки событий планировщика событий, а TRIGGER всегда экспортируются, если--skip-triggers
не указано иное (в соответствии с 7.4.5.3 Сброс хранимых программ )Дайте эту команду для экспорта вашей базы данных, она также будет включать дату
(без пробела после -p)
источник
--databases
будет вставлять операторы какCREATE DATABASE XYZ;
иUSE XYZ;
, что не удобно при импорте SQL в другую БД с другим именем ...Я установил свой wamp-сервер на диск D:, поэтому вам нужно перейти по следующему пути из командной строки ur -> (а если вы установили ur wamp на диск c:, то просто замените d: wtih c: здесь)
здесь root - это пользователь моего phpmyadmin, пароль - это пароль для phpmyadmin, поэтому, если вы не задали пароль для root, просто ничего не указывайте в этом месте, db_name - это база данных (для которой база данных выполняет резервное копирование), backupfile.sql - это файл, в котором вы хотите сделать резервную копию вашей базы данных, и вы также можете изменить расположение файла резервной копии (d: \ backupfile.sql) из любого другого места на вашем компьютере
источник
-p
иpassword
?Пример в localhost
источник
Проблема со всеми этими решениями (с использованием
>
символа перенаправителя) заключается в том, что вы пишете свой дамп из stdout, который может нарушить кодирование некоторых символов вашей базы данных.Если у вас есть проблема с кодировкой символов. Такие как :
тогда вы ДОЛЖНЫ использовать
-r
опцию для записи файла.MySQL
Использование Docker
Примечание: это монтирует текущий путь как дамп внутри экземпляра.
Мы нашли ответ здесь
И наоборот, не используйте
<
для импорта вашего дампа в вашу базу данных, опять же, ваши символы не-utf8 могут не передаваться; но предпочитаю исходный вариант.источник
Синтаксис
пример
где d: \ wamp \ bin \ mysql \ mysql5.6.12 \ bin \ mysqldump.exe будет вашим фактическим путем mysqldump.exe, mydbname - это имя базы данных, которую вы хотите экспортировать, а d: \ mydb.sql - это путь, где Вы хотите сохранить экспортированную базу данных.
источник
Я использовал Wamp-сервер. Я примеряла
root
мое имя пользователя для MySQL, и если у вас есть пароль, укажите его с помощью:Надеюсь, что это работает.
источник
Для ОС Windows :
Когда вы получите ошибку 1064 mysql (42000) при попытке выполнить команду mysqldump , выйдите из текущего терминала. И выполните команду mysqldump.
источник
Я пытался получить дамп базы данных, которая работала в докере, и предложил следующую команду, чтобы добиться того же:
docker exec
<container_id/name>
/ usr / bin / mysqldump -u<db_username>
--password =<db_password>
db_name
> .sqlНадеюсь это поможет!
источник
Вы можете использовать этот скрипт для экспорта или импорта любой базы данных из терминала, указанного по этой ссылке: https://github.com/Ridhwanluthra/mysql_import_export_script/blob/master/mysql_import_export_script.sh
источник