我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.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)来完成此操作。
其他回答
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创建(空)数据库,然后才能导入。
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;
大多数答案都包含>或<字符,这不是所有情况下的正确方法。我建议使用mysqlimport,而您可以使用mysqldump创建转储文件。
这些工具将与mysql服务一起安装,两者都可以在mysql中的一个数据库或多个数据库中进行备份和恢复。
下面是您可以利用它导入mysql的方法
mysqlimport-u database_admin-p数据库名~/path/to/dump_file.sql
如果您没有,请通过以下方式安装:
sudo apt更新sudo apt安装mysql客户端
同样,您可以按如下方式备份转储文件:
mysqldump[选项]--结果文件=dump_file.sql
要将数据库转储到SQL文件中,请使用以下命令。
mysqldump -u username -p database_name > database_name.sql
要将SQL文件导入数据库(确保与SQL文件位于同一目录中或提供文件的完整路径),请执行以下操作:
mysql -u username -p database_name < database_name.sql
如果要导入到本地数据库服务器,可以执行以下操作:
mysql -u database_user -p < database_file.sql
对于远程数据库服务器,请执行以下操作:
mysql -u database_user -p -h remote_server_url < database_file.sql