我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
当前回答
作为参考,我只使用了默认的root+,没有密码。它不适用于所有以前的答案。
我创建了一个具有所有权限和密码的新用户。它奏效了。-没有空格的ppassword。
其他回答
mysqldump的一个常见用法是备份整个数据库:
mysqldump db_name > backup-file.sql
您可以像这样将转储文件加载回服务器:
Unix
mysql db_name < backup-file.sql
在Windows命令提示符中相同:
mysql -p -u [user] [database] < backup-file.sql
PowerShell(PowerShell)
cmd.exe /c "mysql -u root -p db_name < backup-file.sql"
MySQL命令行
mysql> use db_name;
mysql> source backup-file.sql;
转到wamp或xampp目录实例cd d:/wamp/bin/mysql/mysql5.7.24/binmysql-u root-p DATABASENAME<路径数据库文件
我正在使用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 -u root -e "CREATE DATABASE db_name"
mysql db_name --force < import_script.sql
在所有答案中,对于上述问题,这是最好的答案:
mysql> use db_name;
mysql> source file_name.sql;