使用SSH隧道将本地SQL文件导入远程服务器上的MySQL

Jkk*_*Jkk 26 sql ssh import tunnel

我使用putty SSH隧道在localhost和远程服务器之间建立连接.

没关系.

现在我需要一个命令来获取我的本地机器上的sql文件,即c:\ folder\test.sql并将其导入远程服务器上的mysql

我想也许......

mysql -u prefix_username -p testpass -h localhost -P 3307 prefix_testdb
Run Code Online (Sandbox Code Playgroud)

然后做一个像这样的命令

mysql -p testpass -u prefix_username prefix_testdb < c:\folder\test.sql 
Run Code Online (Sandbox Code Playgroud)

这个命令不起作用.

我该如何实现这一目标?

小智 39

您应该运行此命令

mysql -h host -u user_name -pPassword database < file.sql > output.log
Run Code Online (Sandbox Code Playgroud)

file.sql包含要运行的sql查询和output.log只有当你有一个返回某些东西的查询时才有意义(比如select)

我在代码中看到的唯一不同的是-p选项和密码之间的空白.如果使用-p选项,则必须编写密码而不留空格.或者您只需使用选项--password =密码即可

我希望你能解决问题


pau*_*guy 12

您将需要使用附加的mysql命令ssh到远程计算机:

ssh remote_user@remote_server mysql -p testpass -u username testdb < c:\folder\test.sql 
Run Code Online (Sandbox Code Playgroud)


Dai*_*ian 10

 1. mysql -h xxx -uxxx -pxxx . //login to the remote mysql
 2. use DATABASE.             //assign which db to import
 3. source path/to/file.sql  //the path can be your local sql file path.
Run Code Online (Sandbox Code Playgroud)

参考:将SQL文件导入mysql


cb0*_*cb0 6

使用 'scp' 复制并使用 mysql 插入到您的本地机器。

句法:

scp remote_user@remove_server:/path/to/sql/file.sql ~/path/to/local/directory
Run Code Online (Sandbox Code Playgroud)

传输文件后使用:

mysql -uYouUserName -p name_of_database_to_import_to < ~/path/to/local/directory/file.sql
Run Code Online (Sandbox Code Playgroud)