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

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

database_name < file.sql

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

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


当前回答

如果您已经拥有数据库,请使用以下命令导入转储或sql文件:

mysql -u username -p database_name < file.sql

如果不需要在MySQL中创建相关的数据库(空),那么第一次登录MySQL控制台时,可以在终端或cmd中运行以下命令

mysql -u userName -p;

并在提示时提供密码。

接下来,创建一个数据库并使用它:

mysql>create database yourDatabaseName;
mysql>use yourDatabaseName;

然后将sql或转储文件从导入数据库

mysql> source pathToYourSQLFile;

注意:如果您的终端不在转储文件或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创建(空)数据库,然后才能导入。

以下步骤有助于将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输入密码并等待上传完成。

要将数据库转储到SQL文件中,请使用以下命令。

mysqldump -u username -p database_name > database_name.sql

要将SQL文件导入数据库(确保与SQL文件位于同一目录中或提供文件的完整路径),请执行以下操作:

mysql -u username -p database_name < database_name.sql

我认为值得一提的是,您还可以使用zcat加载gzip(压缩)文件,如下所示:

zcat database_file.sql.gz | mysql -u username -p -h localhost database_name

我正在使用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。