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

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

database_name < file.sql

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

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


当前回答

对于导出数据库:

mysqldump -u username -p database_name > file.sql

对于导入数据库:

mysql -u username -p 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

大多数答案都包含>或<字符,这不是所有情况下的正确方法。我建议使用mysqlimport,而您可以使用mysqldump创建转储文件。

这些工具将与mysql服务一起安装,两者都可以在mysql中的一个数据库或多个数据库中进行备份和恢复。

下面是您可以利用它导入mysql的方法

mysqlimport-u database_admin-p数据库名~/path/to/dump_file.sql

如果您没有,请通过以下方式安装:

sudo apt更新sudo apt安装mysql客户端

同样,您可以按如下方式备份转储文件:

mysqldump[选项]--结果文件=dump_file.sql

以下步骤有助于将file.sql上载到MySQL数据库。

步骤1:将file.sql.zip上载到任何目录并在那里解压缩注意:sudo apt-get install unzip:sudo apt-get-unzip文件.sql.zip步骤2:现在导航到该目录。示例:cd/var/www/html

步骤3:mysql-u用户名-p数据库名称<file.sql输入密码并等待上传完成。

添加--force选项:

mysql -u username -p database_name --force < file.sql

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

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