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

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

database_name < file.sql

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

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


当前回答

导入数据库:

mysql-u用户名-p数据库名</file path/file_name.sql

从数据库导出:

mysqldump-u用户名-p数据库名>/file路径/file_name.sql

在这些命令之后,将出现一个提示,询问您的MySQL密码。

其他回答

我正在使用Windows 10和PowerShell 5,我发现几乎所有“类Unix”解决方案都不适合我。

> mysql -u[username] [database-name] < my-database.sql
At line:1 char:31
+ mysql -u[username] [database-name] < my-database.sql
+                               ~
The '<' operator is reserved for future use.
    + CategoryInfo          : ParserError: (:) [], ParentContainsErrorRecordException
    + FullyQualifiedErrorId : RedirectionNotSupported

我最终使用以下命令:

> type my-database.sql | mysql -u[username] -h[localhost] -p [database-name]

它工作得很好,希望能有所帮助。

感谢@Francesco Casula的回答,BTW。

您可以使用:

mysql -u<user> -p<pass> <db> < db.sql

例子:

mysql -uroot -proot db < db.sql

我认为这对那些使用Mac OS X的人可能有用:

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

将xampp替换为mamp或其他web服务器。

我们可以使用此命令从命令行导入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。