我有 .sql
文件,从 phpMyAdmin
导出 . 我想使用命令行将其导入到不同的服务器中 .
我安装了Windows Server 2008 R2 . 我把 .sql
文件放在 C drive 上,我尝试了这个命令
database_name < file.sql
它不起作用我得到语法错误 .
-
如何导入此文件没有问题?
-
我是否需要先创建数据库?
我有 .sql
文件,从 phpMyAdmin
导出 . 我想使用命令行将其导入到不同的服务器中 .
我安装了Windows Server 2008 R2 . 我把 .sql
文件放在 C drive 上,我尝试了这个命令
database_name < file.sql
它不起作用我得到语法错误 .
如何导入此文件没有问题?
我是否需要先创建数据库?
30 回答
如果.sql文件包含
CREATE DATABASE IF NOT EXISTS db_name
和USE db_name
语句,则无需在命令行上指定数据库的名称 .如果.sql文件中提到的数据库不存在,请确保您与具有创建数据库权限的用户进行连接 .
转到MySQL所在的目录 .
同样要转储所有数据库,请使用
-all-databases
选项,不再需要指定数据库的名称 .或者您可以使用SQLyog之类的GUI客户端来执行此操作 .
我正在使用带有Powershell 5的Windows 10,我发现几乎所有“unix-like”解决方案都不适用于我 .
我最终使用此命令 .
它完美无缺,希望它有所帮助 .
感谢@ Francesco Casula的answer顺便说一下 .
要一次导入多个SQL文件,请使用以下命令:
对于简单导入:
对于WAMP:
对于XAMPP:
使用mysql帮助获取详细信息
mysql --help
我认为这些在我们的背景下将是有用的选择
有趣的是,如果我们要导入一个大型数据库而没有进度条 . 使用Pipe Viewer查看通过管道传输的数据
对于Mac,
brew install pv
. 对于Debian / Ubuntu,apt-get install pv
. 其他人,请参考http://www.ivarch.com/programs/pv.shtml有时,定义的端口以及该数据库的服务器IP address也很重要......
我认为值得一提的是,您还可以使用
zcat
加载 gzipped (compressed) 文件,如下所示:我们可以使用此命令从命令行导入SQL:
例如,如果用户名是
root
,密码是password
. 并且您的数据库名称为bank
,SQL文件为bank.sql
. 然后,只需这样做:记住SQL文件的位置 . 如果您的SQL文件位于
Desktop
文件夹/目录中,请转到桌面目录并输入如下命令:如果您位于
Project
目录中,并且您的SQL文件位于Desktop
目录中 . 如果你想从Project
目录访问它,你可以这样做:mysqldump的一个常见用途是用于备份整个数据库:
您可以将转储文件加载回服务器,如下所示:
UNIX
在 Windows 命令提示符中相同:
PowerShell
MySQL command line
对我有用的解决方案如下:
要将数据库转储到SQL文件,请使用以下命令
将SQL文件导入数据库(确保您与SQL文件位于同一目录中或提供文件的完整路径)
尝试:
检查MySQL Options .
Note-1: 最好使用SQL文件
file.sql
的完整路径 .Note-2: 使用
-R
和--triggers
来保留原始数据库的例程和触发器 . 默认情况下不会复制它们 .Note-3 如果它不包含
CREATE DATABASE
(使用--no-create-db
或-n
选项导出),则可能必须从mysql创建(空)数据库,然后才能导入它 .在所有答案中,对于上述问题,这是最好的答案:
出于备份目的,制作BAT文件并使用Task Scheduler运行此BAT文件 . 它将需要备份数据库;只需复制以下行并粘贴Notepad然后保存.bat文件,并在您的系统上运行它 .
最简单的导入到您的架构的方法:
登录mysql并发出以下提示命令 .
打开MySQL命令行
键入mysql bin目录的路径,然后按Enter键
将SQL文件粘贴到mysql服务器的
bin
文件夹中 .在MySQL中创建数据库 .
使用要导入SQL文件的特定数据库 .
键入
source databasefilename.sql
并输入您的SQL文件上传成功 .
我认为这对使用Mac OS X的人有用:
将
xampp
替换为mamp
或其他Web服务器 .导入数据库
添加--force option:
以下步骤有助于将
file.sql
上载到MySQL数据库 .步骤1:将
file.sql.zip
上传到任何目录并在那里解压缩Note :
sudo apt-get install unzip
:sudo apt-get unzip file.sql.zip
第2步:现在导航到该目录 . 示例:
cd /var/www/html
第3步:
mysql -u username -p database-name < file.sql
输入密码并等待上传完成 .
转到您具有MySQL可执行文件的目录 .
-u
用于用户名,-p
用于提示输入密码:有关信息,我只有默认的root withoutpassword,它不适用于以上所有答案 .
我创建了一个具有所有权限和密码的新用户 . 有用 .
-ppassword没有空格 .
虽然这里的大多数答案都提到了简单的命令
今天,数据库和表格的utf8-collation很常见,而这个命令还不够 . 在导出的表中使用utf8-collation,需要使用此命令:
Surley也适用于其他charsets,如何显示正确的符号可以在这里看到:
一条评论还提到,如果数据库永远不存在,则必须首先创建一个空数据库 . 在某些情况下这可能是正确的,但取决于导出文件 . 如果导出的文件已包含创建数据库的命令,则不必在分离的步骤中创建数据库,这甚至可能导致导入时出错 . 所以在导入时,建议首先查看文件中的内容,以了解哪些命令包含在那里,在导出时,建议注意设置,特别是如果文件非常大且难以在编辑器中读取 .
此命令还有更多参数列出和解释:
如果您使用其他数据库版本,请考虑搜索相应的手册版本 . 上面提到的链接指的是MySQL 5.7版 .
如果您已有数据库,请使用以下命令导入
dump
或sql
文件如果你不需要在MySQL中创建相关数据库(空),首先登录到
MySQL
控制台,方法是在终端或cmd中运行以下命令并在提示时提供密码 .
接下来创建一个数据库并使用它
然后将
sql
或dump
文件导入到数据库中注意:如果您的终端不在
dump
或sql
文件所在的位置,请使用上面的相对路径 .要导入单个数据库,请使用以下命令 .
要导入多个数据库转储,请使用以下命令 .
关于导入大文件所花费的时间:最重要的是,由于MySQL的默认设置为
autocommit = true
,因此需要更多时间 . 您必须在导入文件之前将其设置为关闭,然后检查导入如何像gem一样工作 .你只需要做以下事情:
与https://stackoverflow.com/a/17666285/1888983相似
我的主要区别:
数据库必须首先存在
-p
与密码之间没有空格使用MariaDB运行fedora 26 .
以下命令适用于Windows 98上WAMP上的命令行(cmd) .
我一直在遇到没有创建数据库的问题 .
我这样修好了