我离开Linode是因为我没有必要的Linux系统管理技能;在我完成过渡到对新手更友好的服务之前,我需要下载MySQL数据库的内容。是否有一种方法可以从命令行执行此操作?
当前回答
您可以使用mysqldump命令行函数来实现这一点。
例如:
如果它是一个完整的DB,那么:
$ mysqldump -u [uname] -p db_name > db_backup.sql
如果都是db,那么:
$ mysqldump -u [uname] -p --all-databases > all_db_backup.sql
如果它是一个DB中的特定表,那么:
$ mysqldump -u [uname] -p db_name table1 table2 > table_backup.sql
你甚至可以使用gzip自动压缩输出(如果你的DB非常大):
$ mysqldump -u [uname] -p db_name | gzip > db_backup.sql.gz
如果你想远程执行这个操作,并且你有访问服务器的权限,那么下面的方法可以工作(假设MySQL服务器的端口是3306):
$ mysqldump -P 3306 -h [ip_address] -u [uname] -p db_name > db_backup.sql
它应该将.sql文件放到运行命令行的文件夹中。 EDIT:更新以避免在CLI命令中包含密码,使用不带密码的-p选项。它会提示你,而不是记录它。
其他回答
进入MySQL安装目录,并从那里打开cmd。 然后执行下面的命令来获得数据库的备份。
mysqldump -u root -p --add-drop-database --databases db> C:\db-dontdelete\db.sql
不要进入mysql,只要打开命令提示符,然后直接输入:
mysqldump -u [uname] -p[pass] db_name > db_backup.sql
在最新版本的mysql中,至少在我的版本中,你不能直接在命令中输入你的pass。
你必须跑:
mysqldump -u[新]-p db_name > db_backup.sql
然后它会要求输入密码。
如果从远程服务器下载,这里有一个简单的例子:
mysqldump -h my.address.amazonaws.com -u my_username -p db_name > /home/username/db_backup_name.sql
-p表示输入密码,与db_name无关。输入命令后,将提示输入密码。输入它并按enter。
如果你正在运行MySQL而不是默认端口:
mysqldump.exe -u username -p -P PORT_NO database > backup.sql