MySQL: como exportar e importar um ficheiro.sql da linha de comandos? [duplicado]

quero exportar e importar um .ficheiro sql de e para uma base de dados MySQL a partir da linha de comandos.

Existe algum comando para exportar .ficheiro sql no MySQL? Então como posso importá-lo?

ao fazer a importação, poderá haver restrições como activar / desactivar a verificação da chave estrangeira ou exportar apenas a estrutura da tabela .

podemos definir essas opções commysqldump?

Author: AZinkey, 2012-07-10

8 answers

Escreva o seguinte comando para importar o ficheiro de dados sql:

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

Neste exemplo, importar dados.ficheiro sql na base de dados 'blog', usando o vivek como nome de Utilizador:

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

Se tiver um servidor de base de dados dedicado, substitua o nome da máquina localhost pelo nome do servidor ou endereço IP actual como se segue:

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

Para exportar uma base de dados, utilize o seguinte:

mysqldump -u username -p databasename > filename.sql

Note Os símbolos < e > em cada caso.

 39
Author: Frankline, 2012-07-10 06:22:35

Se já estiver a correr a linha de comandos SQL, poderá usar o comando source para importar dados:

use databasename;
source data.sql;
 20
Author: David Kennedy, 2015-01-04 18:05:43

Tenta

mysqldump databaseExample > file.sql
 12
Author: Youcha, 2012-07-10 05:58:14

O Mysqldump não emitirá eventos, gatilhos e rotinas de bases de dados, a menos que explicitamente indicado quando despejar bases de dados individuais;

mysqldump -uuser -p db_name --events --triggers --routines > db_name.sql
 11
Author: PodTech.io, 2016-03-11 13:32:27

Bem, pode usar o comando abaixo para exportar,

Mysqldump --database --user=root --password your_ DB_ name > export_into_db.SQL

E o ficheiro gerado estará disponível na mesma pasta onde você executou este comando.

Ligue-se Agora ao mysql usando o comando,

Mysql-u[utilizador] - p

Então use o comando "source" com a localização do ficheiro.

Pode encontrar mais em: Importar Exportar o MySQL DB

Aprecie:)

 5
Author: Umesh Patil, 2018-06-15 09:30:10

Passa uma base de dados inteira para um ficheiro:

mysqldump -u USERNAME -p password DATABASENAME > FILENAME.sql
 4
Author: Buzz, 2014-01-01 03:54:38
Uma vez que Não tenho reputação suficiente para comentar depois do cargo mais alto, acrescento aqui.

Use ' | ' na plataforma linux para salvar o espaço em disco.

Thx @Haribo, adicionar os parâmetros de eventos/gatilhos/rotinas

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
Algumas questões / dicas:

Erro:......não existe ao usar as tabelas de bloqueio

# --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";

Erro 2006 (HY000) na linha 866: o servidor MySQL desapareceu tenho o errno 32 No 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
Erro 1419 (HY000) na linha 32730: você não tem o SUPER o privilégio e o registo binário estão activos (você Pode querer usar a variável menos segura log_bin_ rest_function_creator)
# set SET GLOBAL log_bin_trust_function_creators = 1;
# or use super user import data
([6]}erro 1227 (42000) na linha 138: Acesso negado; você precisa (pelo menos um) do(s) super privilégio (s) para esta operação tenho o errno 32 No write.
# add sed/awk to avoid some privilege issues
Espero que isto ajude!
 2
Author: Howard.TH, 2017-09-27 02:53:50

Você pode usar esse script para exportar ou importar qualquer banco de dados a partir do terminal dada neste link: 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
 0
Author: Ridhwan Luthra, 2016-10-24 21:20:18