我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.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文件所在的位置,请使用上面的相对路径。
其他回答
转到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)来完成此操作。
您可以尝试此查询。
导出:
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 -u username -p password dbname < dump.sql
要导入多个数据库转储,请使用以下命令。
mysql -u username -p password < dump.sql
作为参考,我只使用了默认的root+,没有密码。它不适用于所有以前的答案。
我创建了一个具有所有权限和密码的新用户。它奏效了。-没有空格的ppassword。
我正在使用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。