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

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

database_name < file.sql

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

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


当前回答

我正在使用Windows 10和PowerShell 5,我发现几乎所有“类Unix”解决方案都不适合我。

> mysql -u[username] [database-name] < my-database.sql
At line:1 char:31
+ mysql -u[username] [database-name] < my-database.sql
+                               ~
The '<' operator is reserved for future use.
    + CategoryInfo          : ParserError: (:) [], ParentContainsErrorRecordException
    + FullyQualifiedErrorId : RedirectionNotSupported

我最终使用以下命令:

> type my-database.sql | mysql -u[username] -h[localhost] -p [database-name]

它工作得很好,希望能有所帮助。

感谢@Francesco Casula的回答,BTW。

其他回答

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

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

您可以尝试此查询。

导出:

mysqldump -u username –-password=your_password database_name > file.sql

导入:

mysql -u username –-password=your_password database_name < file.sql

以及以下链接的详细信息:

https://chartio.com/resources/tutorials/importing-from-and-exporting-to-files-using-the-mysql-command-line/

关于导入巨大文件所需的时间:最重要的是,它需要更多的时间,因为MySQL的默认设置是autocommit=true。您必须在导入文件之前将其设置为关闭,然后检查导入是如何像宝石一样工作的。

您只需执行以下操作:

mysql> use db_name;

mysql> SET autocommit=0 ; source the_sql_file.sql ; COMMIT ;

转到MySQL所在的目录。

 c:\mysql\bin\> mysql -u username -p password database_name <
 filename.sql

此外,要转储所有数据库,请使用-all databases选项,并且不再需要指定数据库的名称。

mysqldump -u username -ppassword –all-databases > dump.sql

或者您可以使用一些GUI客户端(如SQLyog)来完成此操作。