我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
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
作为参考,我只使用了默认的root+,没有密码。它不适用于所有以前的答案。
我创建了一个具有所有权限和密码的新用户。它奏效了。-没有空格的ppassword。
大多数答案都包含>或<字符,这不是所有情况下的正确方法。我建议使用mysqlimport,而您可以使用mysqldump创建转储文件。
这些工具将与mysql服务一起安装,两者都可以在mysql中的一个数据库或多个数据库中进行备份和恢复。
下面是您可以利用它导入mysql的方法
mysqlimport-u database_admin-p数据库名~/path/to/dump_file.sql
如果您没有,请通过以下方式安装:
sudo apt更新sudo apt安装mysql客户端
同样,您可以按如下方式备份转储文件:
mysqldump[选项]--结果文件=dump_file.sql
出于备份目的,创建BAT文件并使用任务调度器运行此BAT文件。它需要备份数据库;只需复制以下行并粘贴到记事本中,然后保存.bat文件,然后在系统上运行它。
@echo off
for /f "tokens=1" %%i in ('date /t') do set DATE_DOW=%%i
for /f "tokens=2" %%i in ('date /t') do set DATE_DAY=%%i
for /f %%i in ('echo %date_day:/=-%') do set DATE_DAY=%%i
for /f %%i in ('time /t') do set DATE_TIME=%%i
for /f %%i in ('echo %date_time::=-%') do set DATE_TIME=%%i
"C:\Program Files\MySQL\mysql server 5.5\bin\mysqldump" -u username -ppassword mysql>C:/%DATE_DAY%_%DATE_TIME%_database.sql
对于Windows操作系统,可以使用以下命令从SQL转储导入数据。
C: \Program Files\MySQL\MySQL Server 5.7\bin>MySQL-u<>-p<>DBName<filelocation\query.sql
其中-u是用户名,-p是MySQL密码。然后输入密码并等待数据导入。