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

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

database_name < file.sql

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

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


当前回答

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

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

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

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

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

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

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

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

其他回答

添加--force选项:

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

使用MySQL Secure Shell:

mysqlsh -u <username> -p -h <host> -D <database name> -f dump.sql

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

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

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

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

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

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

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

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

Try:

mysql -u username -p database_name < file.sql

检查MySQL选项。

注意1:最好使用SQL文件file.SQL的完整路径。

注意2:在mysqldump中使用-R和--triggers来保留原始数据库的例程和触发器。默认情况下不会复制它们。

注意3如果MySQL不存在,并且导出的SQL不包含create database(使用--no create db或-n选项导出),则可能需要从MySQL创建(空)数据库,然后才能导入。

通过终端导入数据库

导航到.sql文件所在的文件夹

然后运行以下命令:

mysql -u database_user_name -p database_name < sql_file_name.sql

它将要求输入密码。输入数据库密码。将数据导入数据库需要几秒钟的时间。