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

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

database_name < file.sql

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

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


当前回答

如果将数据导入Docker容器,请使用以下命令。调整用户(-u)、数据库(-D)、端口(-P)和主机(-h)以适合您的配置。

mysql -u root -D database_name -P 4406 -h localhost --protocol=tcp -p < sample_dump.sql

其他回答

转到MySQL可执行文件所在的目录-u表示用户名,-p表示提示输入密码:

C:\xampp\mysql\bin>mysql -u username -ppassword databasename < C:\file.sql

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

对于导出数据库:

mysqldump -u username -p database_name > file.sql

对于导入数据库:

mysql -u username -p database_name < file.sql

您可以轻松地使用这些步骤。

将SQL文件下载到“mysql/bin”文件夹中。使用CMD打开“mysql/bin”文件夹。如果不存在所需的数据库,则首先创建数据库。在CMD中键入此命令并运行:mysql-u<user>-p<password><dbname><file.sql“file.sql”是要插入到目标数据库中的sql文件。示例:如果您的“密码”是“1234”,“user”是“root”,“dbname”是“test”:mysql-uroot-p1234测试<file.sql如果您的“密码”为空&“user”为“root”&“dbname”为“test”mysql-u根测试<file.sql检查目标数据是否成功上传。

此方法可用于使用CMD中的SQL文件上载大数据。

确保在步骤4中,如果使用该密码,请将“-p”作为一个没有空格的单词插入。

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