我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
当前回答
添加--force选项:
mysql -u username -p database_name --force < file.sql
其他回答
通过终端导入数据库
导航到.sql文件所在的文件夹
然后运行以下命令:
mysql -u database_user_name -p database_name < sql_file_name.sql
它将要求输入密码。输入数据库密码。将数据导入数据库需要几秒钟的时间。
我们可以使用此命令从命令行导入SQL:
mysql -u username -p password db_name < file.sql
例如,如果用户名是root,密码是password。数据库名为bank,SQL文件为bank.SQL
mysql -u root -p password bank < bank.sql
请记住SQL文件的位置。如果SQL文件位于桌面文件夹/目录中,请转到桌面目录并输入如下命令:
cd ~/Desktop
mysql -u root -p password bank < bank.sql
如果您位于Project目录中,并且SQL文件位于Desktop目录中。如果您想从Project目录访问它,可以执行以下操作:
cd ~/Project
mysql -u root -p password bank < ~/Desktop/bank.sql
如果.sql文件包含CREATE database if not EXISTS db_name和USE db_name语句,则不需要在命令行上指定数据库的名称。
如果.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)。
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;