我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。

我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令

database_name < file.sql

它不起作用。我遇到语法错误。

我如何才能毫无问题地导入此文件?我需要先创建数据库吗?


当前回答

这一行在Linux下导入本地数据库中的转储文件。

mysql -u dbuser -p'password including spaces' dbname < path/to/dump_file.sql

这一行在Linux下导入远程数据库中的转储文件。注意:-P表示端口,如果MySQL端口与默认端口不同,则需要-P。

mysql -h dbhost -u dbuser -p'password including spaces' -P 3306 dbname < path/to/dump_file.sql

注意:密码包含空格,这是单引号的原因。只需更改在Windows下使用命令的路径样式(C:\Windows\path\dump_file.sql)。

其他回答

您可以轻松地使用这些步骤。

将SQL文件下载到“mysql/bin”文件夹中。使用CMD打开“mysql/bin”文件夹。如果不存在所需的数据库,则首先创建数据库。在CMD中键入此命令并运行:mysql-u<user>-p<password><dbname><file.sql“file.sql”是要插入到目标数据库中的sql文件。示例:如果您的“密码”是“1234”,“user”是“root”,“dbname”是“test”:mysql-uroot-p1234测试<file.sql如果您的“密码”为空&“user”为“root”&“dbname”为“test”mysql-u根测试<file.sql检查目标数据是否成功上传。

此方法可用于使用CMD中的SQL文件上载大数据。

确保在步骤4中,如果使用该密码,请将“-p”作为一个没有空格的单词插入。

类似于vladkras对如何在MySQL中使用命令行导入SQL文件的回答?。

我的主要区别:

数据库必须首先存在-p和密码之间没有空格


shell> mysql -u root -ppassword #note: no space between -p and password
mysql> CREATE DATABASE databasename;
mysql> using databasename;
mysql> source /path/to/backup.sql

我在MariaDB上运行Fedora 26。

我们可以使用此命令从命令行导入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文件位于桌面文件夹/目录中,请转到桌面目录并输入如下命令:

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

如果您位于Project目录中,并且SQL文件位于Desktop目录中。如果您想从Project目录访问它,可以执行以下操作:

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

作为参考,我只使用了默认的root+,没有密码。它不适用于所有以前的答案。

我创建了一个具有所有权限和密码的新用户。它奏效了。-没有空格的ppassword。

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