如何在MySQL中使用命令行导入SQL文件?

Jaylen 1526 mysql sql import command-line

我有一个.sql导出文件phpMyAdmin.我想使用命令行将其导入到不同的服务器中.

我有一个Windows Server 2008 R2安装.我把.sql文件放在C盘上,我尝试了这个命令

database_name < file.sql

它不起作用我得到语法错误.

  • 如何导入此文件没有问题?
  • 我是否需要先创建数据库?

bansi.. 2954

尝试:

mysql -u username -p database_name < file.sql

检查MySQL选项.

注1:最好使用SQL文件的完整路径file.sql.

注意2:使用-R--triggers保留原始数据库的例程和触发器.默认情况下不会复制它们.

注 - 3如果它不存在,并且导出的SQL不包含CREATE DATABASE(使用--no-create-db-n选项导出),则可能必须从mysql创建(空)数据库,然后才能导入它.

  • 注意,是的,如果它已经不存在,你必须从mysql创建(空)数据库,然后才能导入它. (79认同)
  • Yups,记得在MySQL控制台中创建一个空的数据库(如果db以前不存在),如下所示:`CREATE DATABASE db-name;` (9认同)
  • @Joe,是的,如果'-p'和'password'之间有空格,则认为'password'是数据库名称.或者,您可以在没有密码的情况下键入"-p",然后在按Enter键时会提示您输入密码. (5认同)
  • 当我从像Toad这样的程序运行文件时,我没有错误,但是当我从命令行运行它时,我得到了我提到的错误 (2认同)
  • 请务必检查备份文件中是否包含"use'original_db'".虽然我指定还原到新的数据库"mysql new_db <dump.sql",但是sql转储文件已经存在,并且它覆盖了我的实时数据库.不确定是否有一个选项强制它使用指定的DB并忽略sql文件中的"use'pround_db'" (2认同)

vladkras.. 612

mysqldump的一个常见用途是用于备份整个数据库:

shell> mysqldump db_name > backup-file.sql

您可以将转储文件加载回服务器,如下所示:

UNIX

shell> mysql db_name < backup-file.sql

Windows命令提示符中相同:

mysql -p -u [user] [database] < backup-file.sql

电源外壳

C:\> cmd.exe /c "mysql -u root -p db_name < backup-file.sql"

MySQL命令行

mysql> use db_name;
mysql> source backup-file.sql;

  • 注意使用>将mysqldump输出重定向到文件,特别是如果你想控制编码.相反,您可能希望使用--result-file参数,以便编码不受shell/OS控制. (22认同)

用户甲.. 252

关于导入大文件所花费的时间:最重要的是,由于MySQL的默认设置,它需要更多时间autocommit = true.您必须在导入文件之前将其设置为关闭,然后检查导入如何像gem一样工作.

你只需要做以下事情:

mysql> use db_name;

mysql> SET autocommit=0 ; source the_sql_file.sql ; COMMIT ;

  • 我同意这是**最佳答案**.`autocommit = 0`部分在速度方面创造了一个不同的世界. (14认同)
  • 有没有办法在用于导入的mysql命令的单个命令行中执行此操作? (5认同)
  • 并不总是需要关闭`autocommit`.值得在编辑器中检查数据库转储,它可能已经以`SET autocommit = 0;`开头. (2认同)

Manoj Kumar.. 92

在所有答案中,对于上述问题,这是最好的答案:

 mysql> use db_name;
 mysql> source file_name.sql;


Amrit Dhunga.. 60

我们可以使用此命令从命令行导入SQL:

mysql -u username -p password db_name < file.sql

例如,如果用户名是root,密码是password.并且您有一个数据库名称bank和SQL文件bank.sql.然后,只需这样做:

mysql -u root -p password bank < bank.sql

记住SQL文件的位置.如果您的SQL文件位于Desktop文件夹/目录中,则转到桌面目录并输入如下命令:

~ ? cd Desktop
~/Desktop ? mysql -u root -p password bank < bank.sql

如果您在Project目录中,并且您的SQL文件位于Desktop目录中.如果要从Project目录访问它,那么您可以这样做:

~/Project ? mysql -u root -p password bank < ~/Desktop/bank.sql

  • `-p`和`password`之间不应该有空格 (15认同)
  • 虽然这与这个问题/答案完全无关,但当您使用非平凡的数据库时,不希望以明文形式在同一命令中输入密码.不指定密码作为命令的一部分将提示您输入可以安全输入的密码 (5认同)
  • 为什么你根本无法一行回答?`mysql -u username -ppassword db_name <file.sql` (3认同)

用户甲.. 52

  1. 打开MySQL命令行
  2. 输入mysql bin目录的路径,然后按 Enter
  3. 将您的SQL文件粘贴bin到mysql服务器的文件夹中.
  4. 在MySQL中创建一个数据库.
  5. 使用要导入SQL文件的特定数据库.
  6. 类型source databasefilename.sqlEnter
  7. 您的SQL文件上传成功.


Kasun Siyamb.. 44

如果您已有数据库,请使用以下命令导入dumpsql文件

mysql -u username -p database_name < file.sql

如果你不需要在MySQL中创建相关的数据库(空),那么首先登录到MySQL控制台,方法是在终端或cmd中运行以下命令

mysql -u userName -p;

并在提示时提供密码.

接下来创建一个数据库并使用它

mysql>create database yourDatabaseName;
mysql>use yourDatabaseName;

然后sql将该dump文件或文件导入数据库

mysql> source pathToYourSQLFile;

注意:如果您的终端不在dumpsql存在该文件的位置,请使用上面的相对路径.


用户甲.. 40

对我有用的解决方案如下:

Use your_database_name;
SOURCE path_to_db_sql_file_on_your_local;

  • 有点慢,但不介于两者之间,并没有说MySQL服务器已经消失. (3认同)

用户甲.. 32

转到您具有MySQL可执行文件的目录.-u用于用户名和-p提示输入密码:

C:\xampp\mysql\bin>mysql -u username -ppassword databasename < C:\file.sql

  • 当你为自己的内涵添加一些解释时,我认为对OP和其他问题会更有帮助. (3认同)

用户甲.. 24

要导入单个数据库,请使用以下命令.

mysql -u username -p password dbname < dump.sql

要导入多个数据库转储,请使用以下命令.

mysql -u username -p password < dump.sql


Francesco Ca.. 23

我认为值得一提的是你也可以加载一个压缩的(压缩的)文件,zcat如下所示:

zcat database_file.sql.gz | mysql -u username -p -h localhost database_name


Adeleke Akin.. 23

要将数据库转储到SQL文件,请使用以下命令

mysqldump -u username -p database_name > database_name.sql

将SQL文件导入数据库(确保您与SQL文件位于同一目录中或提供文件的完整路径)

mysql -u username -p database_name < database_name.sql


用户甲.. 15

mysql --user=[user] --password=[password] [database] < news_ml_all.sql


Ammad.. 15

最简单的导入到您的架构的方法:

登录mysql并发出下面提到的命令.

mysql> use your_db_name;

mysql> source /opt/file.sql;


Abdul Rehman.. 13

要一次导入多个SQL文件,请使用以下命令:

# Unix-based solution
for i in *.sql;do mysql -u root -pPassword DataBase < $i;done

对于简单导入:

# Unix-based solution
mysql -u root -pPassword DataBase < data.sql

对于WAMP:

#mysqlVersion replace with your own version
C:\wamp\bin\mysql\mysqlVersion\bin\mysql.exe -u root -pPassword DataBase < data.sql

对于XAMPP:

C:\xampp\mysql\bin\mysql -u root -pPassword DataBase < data.sql


Reuben.. 12

如果.sql文件包含CREATE DATABASE IF NOT EXISTS db_nameUSE db_name语句,则无需在命令行上指定数据库的名称.

如果.sql文件中提到的数据库不存在,请确保您与具有创建数据库权限的用户进行连接.


Pritam Chaud.. 11

导入数据库

  1. 去开车:

    command: d:
    
  2. MySQL登录

    command: c:\xampp\mysql\bin\mysql -u root -p
    
  3. 它会要求密码.输入它:

    pwd
    
  4. 选择数据库

    use DbName;
    
  5. 提供文件名

    \.DbName.sql
    


ktaria.. 9

添加--force选项:

mysql -u username -p database_name --force < file.sql


Sathish D.. 8

转到MySQL所在的目录.

 c:\mysql\bin\> mysql -u username -p password database_name <
 filename.sql

同样要转储所有数据库,请使用该-all-databases选项,不再需要指定数据库的名称.

mysqldump -u username -ppassword –all-databases > dump.sql

或者您可以使用SQLyog之类的GUI客户端来执行此操作.


Giri.. 7

我认为它对那些使用Mac OS X的人有用:

/Applications/xampp/xamppfiles/bin/mysql -u root -p database < database.sql

替换xamppmamp或其他Web服务器.


用户甲.. 7

以下命令适用于WAMP上Windows 7上的命令行(cmd).

d:/wamp/bin/mysql/mysql5.6.17/bin/mysql.exe -u root -p db_name < database.sql


Siva Praveen.. 6

mysql -u root -p password -D database_name << import.sql

使用mysql帮助获取详细信息 mysql --help

我认为这些在我们的背景下将是有用的选择

[~]$ mysql --help
mysql  Ver 14.14 Distrib 5.7.20, for osx10.12 (x86_64) using  EditLine wrapper
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.                                                                                                                                         
Usage: mysql [OPTIONS] [database]
  -?, --help          Display this help and exit.
  -I, --help          Synonym for -?
  --bind-address=name IP address to bind to.
  -D, --database=name Database to use.
  --delimiter=name    Delimiter to be used.
  --default-character-set=name Set the default character set.
  -f, --force         Continue even if we get an SQL error.
  -p, --password[=name] Password to use when connecting to server.
  -h, --host=name     Connect to host.
  -P, --port=#        Port number to use for connection or 0 for default to, in order of preference, my.cnf, $MYSQL_TCP_PORT, /etc/services, built-in default (3306).
  --protocol=name     The protocol to use for connection (tcp, socket, pipe,
  -s, --silent        Be more silent. Print results with a tab as separator, each row on new line.
  -v, --verbose       Write more. (-v -v -v gives the table output format).
  -V, --version       Output version information and exit.
  -w, --wait          Wait and retry if connection is down.

有趣的是,如果我们要导入一个大型数据库而没有进度条.使用Pipe Viewer查看通过管道传输的数据

对于Mac brew install pv ,.对于Debian/Ubuntu , apt-get install pv. 其他,请参阅http://www.ivarch.com/programs/pv.shtml

pv import.sql | mysql -u root -p password -D database_name

1.45GiB 1:50:07 [339.0KiB/s]   [=============>      ] 14% ETA 11:09:36
1.46GiB 1:50:14 [ 246KiB/s]     [=============>      ] 14% ETA 11:09:15
1.47GiB 1:53:00 [ 385KiB/s]     [=============>      ] 14% ETA 11:05:36


David.. 6

虽然这里的大多数答案都提到了简单的命令

mysql -u database_user -p [db_name] <database_file.sql

今天,数据库和表格的utf8-collat​​ion很常见,而这个命令还不够.在导出的表中使用utf8-collat​​ion,需要使用此命令:

mysql -u database_user -p --default-character-set = utf8 [db_name] <database_file.sql

Surley这也适用于其他charsets,如何显示正确的符号可以在这里看到:

https://dev.mysql.com/doc/refman/5.7/en/show-collat​​ion.html

一条评论还提到,如果数据库永远不存在,则必须首先创建一个空数据库.在某些情况下,这可能是正确的,但取决于导出文件.如果导出的文件已包含用于创建数据库的命令,则永远不必在分离的步骤中创建数据库,这甚至可能导致导入时出错.所以在导入时,建议首先查看文件中的内容以了解哪些命令包含在那里,在导出时建议注意设置,特别是如果文件非常大且难以在编辑器中读取.

此命令还有更多参数列出和解释:

https://dev.mysql.com/doc/refman/5.7/en/mysql-command-options.html

如果您使用其他数据库版本,请考虑搜索相应的手册版本.上面提到的链接指的是MySQL 5.7版.


用户甲.. 5

有时,定义的端口以及该数据库的服务器IP地址也很重要......

mysql -u user -p user -h <Server IP> -P<port> (DBNAME) < DB.sql 


用户甲.. 5

出于备份目的,创建BAT文件并使用任务计划程序运行此BAT文件.它将需要备份数据库; 只需复制以下行并粘贴到记事本中,然后保存.bat文件,并在您的系统上运行它.

@echo off
for /f "tokens=1" %%i in ('date /t') do set DATE_DOW=%%i
for /f "tokens=2" %%i in ('date /t') do set DATE_DAY=%%i
for /f %%i in ('echo %date_day:/=-%') do set DATE_DAY=%%i
for /f %%i in ('time /t') do set DATE_TIME=%%i
for /f %%i in ('echo %date_time::=-%') do set DATE_TIME=%%i

"C:\Program Files\MySQL\mysql server 5.5\bin\mysqldump" -u username -ppassword mysql>C:/%DATE_DAY%_%DATE_TIME%_database.sql


David Silva .. 5

我一直在遇到没有创建数据库的问题.

我这样修好了

mysql -u root -e "CREATE DATABASE db_name"
mysql db_name --force < import_script.sql


提问时间:

查看次数:

2514085 次

最近活跃:

9 月,1 周 前