1. 备份
因为我本地用了python的anaconda3环境,所以一直有个base,里面也有个mysql,一直无法执行备份,所以需要先执行命令关闭conda
conda deactivate
不要自动启动base
conda config --set auto_activate_base false
先进入需要备份的服务器上,找到mysql服务是否开启,若开启则继续,否则需要先启动mysql服务。
前提:有数据库访问用户、密码、数据库名,端口号如果不是默认需要加参数--port=your_port
如果您想要备份整个数据库,请执行以下mysqldump命令:
mysqldump -q -uyour_user -pyour_password --databases your_database > path_to_your_backup_file.sql
如果您只想备份单个表,则请执行以下mysqldump命令:
mysqldump -q -uyour_user -pyour_password your_database your_tablename > backupfile.sql
your_user是数据库用户名
your_password是数据库密码,
your_database是表所在的数据库名,
your_tablename是需要备份的表名,
backupfile.sql是备份文件名。执行该命令后,会将指定的表备份到backupfile.sql文件中。
2. 还原
切换到你想要还原的服务器上,把上面生成的sql文件复制到这台要还原的机子上。
如果您想要还原整个数据库,请执行以下mysql命令:
mysql -uyour_user -pyour_password --port=3305 dbname < backupfile.sql
如果您只想还原单个表,则请执行以下mysql命令:
mysql -uyour_user -pyour_password --port=3305 dbname < backupfile.sql
注意:在上述的命令之中,username是数据库用户名,password是数据库密码,dbname是表所在的数据库名,backupfile.sql是备份文件名。执行该命令后,会将指定的表还原到指定的数据库中。
我用上述命令没起作用,后来尝试了下面这种方式:
如果下面想要直接使用文件,先cd 命令到backupfile.sql所在的目录,然后执行命令
# 输入命令进入mysql
mysql -u username -p --port=3306
# 输入你的用户的密码, enter后进入mysql
# 输入命令切换数据库:
use your_database;
# 输入命令还原数据库:
SOURCE backupfile.sql