MySQL数据库备份为sql文件还原到另一个服务器

1. 备份

因为我本地用了python的anaconda3环境,所以一直有个base,里面也有个mysql,一直无法执行备份,所以需要先执行命令关闭conda

bash 复制代码
conda deactivate

不要自动启动base

bash 复制代码
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所在的目录,然后执行命令

bash 复制代码
# 输入命令进入mysql
mysql -u username -p --port=3306 

# 输入你的用户的密码, enter后进入mysql

# 输入命令切换数据库:
use your_database;

# 输入命令还原数据库:
SOURCE backupfile.sql 
相关推荐
MAGICIAN...6 小时前
【Redis】--持久化机制
数据库·redis·缓存
我真的是大笨蛋6 小时前
JVM调优总结
java·jvm·数据库·redis·缓存·性能优化·系统架构
步步为营DotNet8 小时前
5-2EFCore性能优化
数据库·性能优化·.net
2501_920047039 小时前
Redis-集群
数据库·redis·bootstrap
半夏陌离9 小时前
SQL 拓展指南:不同数据库差异对比(MySQL/Oracle/SQL Server 基础区别)
大数据·数据库·sql·mysql·oracle·数据库架构
旋转的油纸伞10 小时前
SQL表一共有几种写入方式
数据库·sql
半夏陌离10 小时前
SQL 入门指南:排序与分页查询(ORDER BY 多字段排序、LIMIT 分页实战)
java·前端·数据库
isyoungboy10 小时前
SQL高效处理海量GPS轨迹数据:人员gps轨迹数据抽稀实战指南
数据库·sql
敬业小码哥10 小时前
记一次:mysql的json及json数组使用组合使用
数据库·mysql·json
练小杰11 小时前
【Mysql-installer-community-8.0.26.0】Mysql 社区版(8.0.26.0) 在Window 系统的默认安装配置
数据库·sql·mysql·adb·配置文件·mysql安装·关系型数据库