Как экспортировать и импортировать файл .sql из командной строки с параметрами? [Дубликат]

271

Я хочу экспортировать и импортировать файл .sql из базы данных MySQL из командной строки из командной строки.

Есть ли какая-либо команда для экспорта файла .sql в MySQL? Затем как его импортировать?

При выполнении импорта могут быть ограничения, такие как включить/отключить проверку внешнего ключа или экспортировать только структуру таблицы.

Можем ли мы установить те параметры с помощью mysqldump?

  • 4
    mysqldump - это отдельная команда. Вы не должны быть в mysql при запуске. Просто напишите это перед командной строкой. И точка с запятой должна сообщить приглашению mysql, что команда завершилась. Поскольку вы запускаете mysqldump в качестве программы на терминале, вам не следует заканчивать его точкой с запятой.
  • 0
    спасибо Ozair & всем парням также есть ли способ установить атрибуты, такие как установить внешний ключ, только структура, только данные
Показать ещё 3 комментария
Теги:
command-line
command-line-arguments
sqlcommand

9 ответов

477
Лучший ответ

Экспортировать

Если это полная БД, то:

$ mysqldump -u [uname] -p[pass] db_name > db_backup.sql

Если все БД, то:

$ mysqldump -u [uname] -p[pass] --all-databases > all_db_backup.sql

Если это конкретные таблицы в БД, то:

$ mysqldump -u [uname] -p[pass] db_name table1 table2 > table_backup.sql

Вы даже можете сделать автоматическое сжатие вывода с помощью gzip (если ваша БД очень большая):

$ mysqldump -u [uname] -p[pass] db_name | gzip > db_backup.sql.gz

Если вы хотите сделать это удаленно и у вас есть доступ к серверу, то будет работать следующее (предполагая, что сервер MySQL находится на порту 3306):

$ mysqldump -P 3306 -h [ip_address] -u [uname] -p[pass] db_name > db_backup.sql

Чтобы импортировать

Введите следующую команду для импорта файла данных sql:

$ mysql -u username -p -h localhost DATA-BASE-NAME < data.sql

В этом примере импортируйте файл data.sql в базу данных "blog", используя sat в качестве имени пользователя:

$ mysql -u sat -p -h localhost blog < data.sql

Если у вас есть выделенный сервер базы данных, замените имя хоста localhost на фактическое имя сервера или IP-адрес следующим образом:

$ mysql -u username -p -h 202.54.1.10 databasename < data.sql

ИЛИ использовать имя хоста, например mysql.cyberciti.biz

$ mysql -u username -p -h mysql.cyberciti.biz database-name < data.sql

Если вы не знаете, что имя базы данных или имя базы данных включено в дамп sql, вы можете попробовать что-то следующее:

$ mysql -u username -p -h 202.54.1.10 < data.sql

Refer: http://dev.mysql.com/doc/refman/5.6/en/mysqldump.html

Если вы хотите использовать графический интерфейс, то вы, вероятно, можете использовать SQLyog

56

Введите следующую команду для импорта файла данных sql:

$ mysql -u username -p -h localhost DATA-BASE-NAME < data.sql

В этом примере импортируйте файл data.sql в базу данных "blog", используя vivek как имя пользователя:

$ mysql -u vivek -p -h localhost blog < data.sql

Если у вас есть выделенный сервер базы данных, замените имя хоста localhost на фактическое имя сервера или IP-адрес следующим образом:

$ mysql -u username -p -h 202.54.1.10 databasename < data.sql

Чтобы экспортировать базу данных, используйте следующее:

mysqldump -u username -p databasename > filename.sql

Обратите внимание на символы < и > в каждом случае.

23

Если вы уже используете оболочку SQL, вы можете использовать команду source для импорта данных:

use databasename;
source data.sql;
  • 0
    Лучший вариант для импорта дампированных данных. Если вы экспортировали данные с помощью mysqldump, то эта опция для импорта будет работать в считанные секунды.
14

Попробуйте

mysqldump databaseExample > file.sql
  • 1
    не работать таким образом
13

mysqldump не будет удалять события базы данных, триггеры и процедуры, если явно не указано при сбросе отдельных баз данных;

mysqldump -uuser -p db_name --events --triggers --routines > db_name.sql
  • 0
    Я не знаю, почему этот ответ не набрал много голосов. Это единственный ответ, который указывает на - --events .. В любом случае, на мой взгляд, большое спасибо, спасибо :-)
  • 0
    Это правильный ответ!
Показать ещё 2 комментария
9

Ну, вы можете использовать команду ниже для экспорта,

mysqldump --database - -u ser = root --password your_db_name> export_into_db.sql

и сгенерированный файл будет доступен в том же каталоге, где вы выполнили эту команду.

Теперь войдите в MySQL, используя команду,

mysql -u [имя пользователя] -p

затем используйте команду "source" с путем к файлу.

5

Удалите всю базу данных в файл:

mysqldump -u USERNAME -p password DATABASENAME > FILENAME.sql
  • 0
    И как мы можем установить ограничения, такие как включить / отключить проверку внешнего ключа или экспортировать только структуру таблицы с mysqldump
3

так как у меня нет достаточной репутации для комментариев после самой высокой записи, поэтому я добавляю здесь.

использовать '|' на платформе linux для сохранения дискового пространства.

спасибо @Hariboo, добавить параметры событий/триггеров/маршрутов

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

некоторые вопросы/советы:

Ошибка:...... не существует при использовании 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";

ОШИБКА 2006 (HY000) в строке 866: сервер MySQL ушел mysqldump: Получил errno 32 при записи

# 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

ОШИБКА 1419 (HY000) в строке 32730: у вас нет привилегии SUPER, и двоичный журнал включен (вы можете использовать менее безопасную переменную log_bin_trust_function_creators)

# set SET GLOBAL log_bin_trust_function_creators = 1;
# or use super user import data

ОШИБКА 1227 (42000) в строке 138: Доступ запрещен; вам нужна (по крайней мере, одна из) привилегия SUPER для этой операции mysqldump: Получил errno 32 при записи

# add sed/awk to avoid some privilege issues

надеюсь, что эта помощь!

  • 0
    Я столкнулся с ошибкой 1227 (42000). Не уверен, что вы имели в виду, добавив sed / awk.
-1

Вы можете использовать этот script для экспорта или импорта любой базы данных из терминала, указанного по этой ссылке: 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

Ещё вопросы

Сообщество Overcoder
Наверх
Меню