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

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

database_name < file.sql

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

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


当前回答

如果您已经拥有数据库,请使用以下命令导入转储或sql文件:

mysql -u username -p database_name < file.sql

如果不需要在MySQL中创建相关的数据库(空),那么第一次登录MySQL控制台时,可以在终端或cmd中运行以下命令

mysql -u userName -p;

并在提示时提供密码。

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

mysql>create database yourDatabaseName;
mysql>use yourDatabaseName;

然后将sql或转储文件从导入数据库

mysql> source pathToYourSQLFile;

注意:如果您的终端不在转储文件或sql文件所在的位置,请使用上面的相对路径。

其他回答

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

我是这样修复的:

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

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

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

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

如果您在Mac OS X上使用MAMP,这可能会有所帮助:

/applications/MAMP/library/bin/mysql -u MYSQL_USER -p DATABASE_NAME < path/to/database_sql/FILE.sql

MYSQL_USER默认为root。

这一行在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)。

转到MySQL所在的目录。

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

此外,要转储所有数据库,请使用-all databases选项,并且不再需要指定数据库的名称。

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

或者您可以使用一些GUI客户端(如SQLyog)来完成此操作。