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

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

database_name < file.sql

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

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


当前回答

要导入数据库,请使用以下命令。

mysql> create new_database;
mysql> use new_database;
mysql> source (Here you need to import the path of the SQL file);

E.g.:
mysql> source E:/test/dump.sql;

即使在Windows上,也需要使用正斜杠(/),例如e:/test/dump.sql而不是e:\test\dump.sql

或由于转义而使用双反斜杠(\\),即e:\\test\\dump.sql

其他回答

易于理解的只需在cmd中使用此命令:

use databasename
\. C:/test/data.mysql

打开MySQL命令行键入mysql bin目录的路径,然后按Enter键将SQL文件粘贴到mysql服务器的bin文件夹中。在MySQL中创建数据库。使用要导入SQL文件的特定数据库。键入source databasefilename.sql并输入SQL文件上载成功。

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

mysqldump db_name > backup-file.sql

您可以像这样将转储文件加载回服务器:

Unix

mysql db_name < backup-file.sql

在Windows命令提示符中相同:

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

PowerShell(PowerShell)

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

MySQL命令行

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

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

我是这样修复的:

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

我认为值得一提的是,您还可以使用zcat加载gzip(压缩)文件,如下所示:

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