我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
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)。
其他回答
通过终端导入数据库
导航到.sql文件所在的文件夹
然后运行以下命令:
mysql -u database_user_name -p database_name < sql_file_name.sql
它将要求输入密码。输入数据库密码。将数据导入数据库需要几秒钟的时间。
以下命令在上的命令行(cmd)中对我有效WAMP上的Windows 7。
d:/wamp/bin/mysql/mysql5.6.17/bin/mysql.exe -u root -p db_name < database.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)来完成此操作。
您可以使用:
mysql -u<user> -p<pass> <db> < db.sql
例子:
mysql -uroot -proot db < db.sql
在命令行上提供凭据不是一个好主意。以上答案很好,但忽略了提及
mysql --defaults-extra-file=etc/myhost.cnf database_name < file.sql
其中etc/myhost.cnf是包含主机、用户和密码的文件,您可以避免在命令行中暴露密码。这是一个样本,
[client]
host=hostname.domainname
user=dbusername
password=dbpassword