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

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

database_name < file.sql

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

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


当前回答

导入到架构的最简单方法:

登录mysql并发出以下提到的命令。

mysql> use your_db_name;

mysql> source /opt/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创建(空)数据库,然后才能导入。

作为参考,我只使用了默认的root+,没有密码。它不适用于所有以前的答案。

我创建了一个具有所有权限和密码的新用户。它奏效了。-没有空格的ppassword。

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

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

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

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

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

虽然这里的大多数答案只提到了简单的命令

mysql-u数据库用户-p[db_name]<数据库文件.sql

今天,数据库和表具有utf8排序规则是很常见的,而这个命令还不够。在导出的表中具有utf8排序规则,需要使用以下命令:

mysql -u database_user -p  --default-character-set=utf8 [db_name] < database_file.sql

相应的导出可以使用

mysqldump -u database_user -p --default-character-set=utf8 [db_name] > database_file.sql

当然,这也适用于其他字符集,如何显示正确的符号可以在这里看到:

https://dev.mysql.com/doc/refman/5.7/en/show-collation.html

一条评论还提到,如果数据库从不存在,则必须首先创建一个空数据库。这在某些情况下可能是正确的,但取决于导出文件。如果导出的文件中已经包含创建数据库的命令,那么就不必在单独的步骤中创建数据库,这甚至会导致导入时出错。因此,在导入时,建议先查看该文件,以了解其中包含哪些命令;在导出时,建议注意设置,尤其是如果文件非常大且在编辑器中难以读取时。

下面列出并解释了该命令的更多参数:

https://dev.mysql.com/doc/refman/5.7/en/mysql-command-options.html

如果您使用其他数据库版本,请考虑搜索相应版本的手册。上述链接参考MySQL 5.7版。

编辑:同样的参数也适用于mysqldump。因此,虽然导出和导入的命令不同,但上述参数不同。尽管如此,手册中有一个专门的站点描述了mysqldump的选项:https://dev.mysql.com/doc/refman/5.7/en/mysqldump.html