我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < 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
其他回答
以下命令在上的命令行(cmd)中对我有效WAMP上的Windows 7。
d:/wamp/bin/mysql/mysql5.6.17/bin/mysql.exe -u root -p db_name < database.sql
转到MySQL可执行文件所在的目录-u表示用户名,-p表示提示输入密码:
C:\xampp\mysql\bin>mysql -u username -ppassword databasename < C:\file.sql
我认为值得一提的是,您还可以使用zcat加载gzip(压缩)文件,如下所示:
zcat database_file.sql.gz | mysql -u username -p -h localhost database_name
导入数据库
转到驱动器:d:MySQL登录c: \xamp\mysql\bin\mysql-u root-p它将要求pwd。输入:压水堆选择数据库使用DbName;提供文件名\.DbName.sql
关于导入巨大文件所需的时间:最重要的是,它需要更多的时间,因为MySQL的默认设置是autocommit=true。您必须在导入文件之前将其设置为关闭,然后检查导入是如何像宝石一样工作的。
您只需执行以下操作:
mysql> use db_name;
mysql> SET autocommit=0 ; source the_sql_file.sql ; COMMIT ;