我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
当前回答
在Ubuntu中
mysql -u root -p
CREATE database dbname;
use dbname;
source /home/computername/Downloads/merchantapp.sql
exit;
在Windows中
下载SQL文件并将其保存在C:\xamp\mysql\bin中。
之后,使用C:\xamp\mysql\bin打开命令提示符:
C:\xampp\mysql\bin> mysql -u username -p database_name < file.sql
其他回答
如果您的文件夹有多个SQL文件,并且您安装了Git Bash,则可以使用此命令导入多个文件:
cd /my-project/data
cat *.sql | /c/xampp/mysql/bin/mysql -u root -p 1234 myProjectDbName
有时定义的端口以及该数据库的服务器IP地址也很重要。。。
mysql -u user -p user -h <Server IP address> -P<port> (DBNAME) < DB.sql
如果.sql文件包含CREATE database if not EXISTS db_name和USE db_name语句,则不需要在命令行上指定数据库的名称。
如果.sql文件中提到的数据库不存在,请确保您正在与具有创建数据库权限的用户进行连接。
我认为值得一提的是,您还可以使用zcat加载gzip(压缩)文件,如下所示:
zcat database_file.sql.gz | mysql -u username -p -h localhost database_name
导出特定数据库:
mysqldump --user=root --host=localhost --port=3306 --password=test -B CCR KIT > ccr_kit_local.sql
这将导出CCR和KIT数据库。。。
将所有导出的数据库导入到特定的MySQL实例(您必须在转储文件所在的位置):
mysql --user=root --host=localhost --port=3306 --password=test < ccr_kit_local.sql