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

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

database_name < file.sql

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

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


当前回答

在命令行上提供凭据不是一个好主意。以上答案很好,但忽略了提及

mysql --defaults-extra-file=etc/myhost.cnf database_name < file.sql

其中etc/myhost.cnf是包含主机、用户和密码的文件,您可以避免在命令行中暴露密码。这是一个样本,

[client]
host=hostname.domainname
user=dbusername
password=dbpassword

其他回答

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

在所有答案中,对于上述问题,这是最好的答案:

 mysql> use db_name;
 mysql> source file_name.sql;

如果您正在使用XAMPP,请转到文件夹xappp→ mysql数据库→ 箱子在此处打开cmd并粘贴:

mysql -u root -p dbname < dbfilename.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