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

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

database_name < file.sql

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

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


当前回答

在MySQL中创建数据库。然后转到计算机目录C:\xamp\mysql\bin,在地址栏中写入cmd,然后按Enter键。解压缩SQL文件然后写:mysql-uroot-pdbname并按Enter键。写:source sql.file。类似于源C:\xamp\htdocs\amarbazarltd\st1159.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)来完成此操作。

类似于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。

您可以尝试此查询。

导出:

mysqldump -u username –-password=your_password database_name > file.sql

导入:

mysql -u username –-password=your_password database_name < file.sql

以及以下链接的详细信息:

https://chartio.com/resources/tutorials/importing-from-and-exporting-to-files-using-the-mysql-command-line/

有时定义的端口以及该数据库的服务器IP地址也很重要。。。

mysql -u user -p user -h <Server IP address> -P<port> (DBNAME) < DB.sql

对我有效的解决方案如下:

Use your_database_name;
SOURCE path_to_db_sql_file_on_your_local;