我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
我有一个.sql文件,其中包含phpMyAdmin的导出。我想使用命令行将其导入到其他服务器。
我安装了Windows Server 2008 R2。我将.sql文件放在C驱动器上,并尝试了以下命令
database_name < file.sql
它不起作用。我遇到语法错误。
我如何才能毫无问题地导入此文件?我需要先创建数据库吗?
当前回答
我认为值得一提的是,您还可以使用zcat加载gzip(压缩)文件,如下所示:
zcat database_file.sql.gz | mysql -u username -p -h localhost database_name
其他回答
打开MySQL命令行键入mysql bin目录的路径,然后按Enter键将SQL文件粘贴到mysql服务器的bin文件夹中。在MySQL中创建数据库。使用要导入SQL文件的特定数据库。键入source databasefilename.sql并输入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;
在命令行上提供凭据不是一个好主意。以上答案很好,但忽略了提及
mysql --defaults-extra-file=etc/myhost.cnf database_name < file.sql
其中etc/myhost.cnf是包含主机、用户和密码的文件,您可以避免在命令行中暴露密码。这是一个样本,
[client]
host=hostname.domainname
user=dbusername
password=dbpassword
您可以轻松地使用这些步骤。
将SQL文件下载到“mysql/bin”文件夹中。使用CMD打开“mysql/bin”文件夹。如果不存在所需的数据库,则首先创建数据库。在CMD中键入此命令并运行:mysql-u<user>-p<password><dbname><file.sql“file.sql”是要插入到目标数据库中的sql文件。示例:如果您的“密码”是“1234”,“user”是“root”,“dbname”是“test”:mysql-uroot-p1234测试<file.sql如果您的“密码”为空&“user”为“root”&“dbname”为“test”mysql-u根测试<file.sql检查目标数据是否成功上传。
此方法可用于使用CMD中的SQL文件上载大数据。
确保在步骤4中,如果使用该密码,请将“-p”作为一个没有空格的单词插入。
对我有效的解决方案如下:
Use your_database_name;
SOURCE path_to_db_sql_file_on_your_local;