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

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

database_name < file.sql

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

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


当前回答

使用MySQL Secure Shell:

mysqlsh -u <username> -p -h <host> -D <database name> -f dump.sql

其他回答

类似于vladkras对如何在MySQL中使用命令行导入SQL文件的回答?。

我的主要区别:

数据库必须首先存在-p和密码之间没有空格


shell> mysql -u root -ppassword #note: no space between -p and password
mysql> CREATE DATABASE databasename;
mysql> using databasename;
mysql> source /path/to/backup.sql

我在MariaDB上运行Fedora 26。

如果您正在使用XAMPP,请转到文件夹xappp→ mysql数据库→ 箱子在此处打开cmd并粘贴:

mysql -u root -p dbname < dbfilename.sql

导入数据库

转到驱动器:d:MySQL登录c: \xamp\mysql\bin\mysql-u root-p它将要求pwd。输入:压水堆选择数据库使用DbName;提供文件名\.DbName.sql

对于导出数据库:

mysqldump -u username -p database_name > file.sql

对于导入数据库:

mysql -u username -p database_name < file.sql

这一行在Linux下导入本地数据库中的转储文件。

mysql -u dbuser -p'password including spaces' dbname < path/to/dump_file.sql

这一行在Linux下导入远程数据库中的转储文件。注意:-P表示端口,如果MySQL端口与默认端口不同,则需要-P。

mysql -h dbhost -u dbuser -p'password including spaces' -P 3306 dbname < path/to/dump_file.sql

注意:密码包含空格,这是单引号的原因。只需更改在Windows下使用命令的路径样式(C:\Windows\path\dump_file.sql)。