cmd mysql 数据分析_【数据分析师_02_SQL+MySQL】030_MySQL的数据备份和性能管理(MYSQLDUMP,MYSQLHOTCOPY,INDEX,EXPLAIN)...

MySQL的数据备份和性能管理

1 概述

1.1 数据备份

像所有数据一样,MySQL的数据也必须经常备份。由于MySQL数据库是基于磁盘的文件,普通的备份系统和例程就能备份MySQL的数据。但是,由于这些文件总是处于打开和使用状态,普通的文件副本备份不一定总是有效。

使用命令行实用程序 mysqldump 转储所有数据库内容到某个外部文件。在进行常规备份前这个实用程序应该正常运行,以便能正确地备份转储文件。

可用命令行实用程序 mysqlhotcopy 从一个数据库复制所有数据(并非所有数据库引擎都支持这个实用程序)。

可以使用MySQL的 BACKUP TABLE 或 SELECT INTO OUTFILE 转储所有数据到某个外部文件。

1.2 性能管理(索引 Index)

数据库工作人员把他们工作中的相当一部份时间花在了性能调整上、试验改善DBMS性能。

在诊断应用的滞缓现象和性能问题时,性能不良的数据库(以及数据库查询)通常是最常见的祸因。

利用索引 Index 可以大幅改善查询时候的性能问题。

利用一些操作系统的参数也可以提供数据访问的性能。

使用 Explain 语句让MySQL解释它将如何执行一条SELECT语句。

一般来说,存储过程执行得比一条一条地执行其中的各条MySQL语句快

2 数据备份

MySQL中自带了 mysqldump功能,可以以此功能进行数据备份

2.1 利用 NAVICAT备份

注:右键可以查看备份位置

c7c9cdae7b6616b8dc07ff88dac83d54.png

2.2 利用 CMD备份

2.2.1 备份一个数据库

d:\mysql\bin>mysqldump.exe -h 127.0.0.1 -p 3306 -uroot -p --database erp > d:\mysql\create_db_1.sql

# 运行程序mysqldump.exe -h 本机 -p port是3306 登陆root账户 -p --选择erp数据库进行备份 > 备份位置\备份文件的名称

2.2.2 备份多个表

d:\mysql\bin>mysqldump.exe -h 127.0.0.1 -p 3306 -uroot -p erp orders> d:\mysql\create_orders.sql

# 运行程序mysqldump.exe -h 本机 -p port是3306 登陆root账户 -p --选择erp数据库中的orders表进行备份 > 备份位置\备份文件的名称

2.2.3 备份多个数据库

d:\mysql\bin>mysqldump.exe -h 127.0.0.1 -p 3306 -uroot -p --database erp test > d:\mysql\create_db_2.sql

# 运行程序mysqldump.exe -h 本机 -p port是3306 登陆root账户 -p --选择erp和test数据库进行备份 > 备份位置\备份文件的名称

2.2.4 备份所有数据库

d:\mysql\bin>mysqldump.exe -h 127.0.0.1 -p 3306 -uroot -p --all-database d:\mysql\create_db_all.sql

# 运行程序mysqldump.exe -h 本机 -p port是3306 登陆root账户 -p --选择所有数据库进行备份 > 备份位置\备份文件的名称

2.3 备份空数据库(测试用)

d:\mysql\bin>mysqldump.exe -h 127.0.0.1 -p 3306 -uroot -p --no-data --database erp d:\mysql\create_db_blank.sql

# 运行程序mysqldump.exe -h 本机 -p port是3306 登陆root账户 -p --不选择数据 --选择所有数据库进行备份 > 备份位置\备份文件的名称

2.4 数据的导入/导出

导出数据:

SELECT * FROM customers INTO OUTFILE 'd:\mysql\out.csv'

导入数据:

(customers2 是一张空表,此时将导出的数据重新载入空表中)

SELECT * FROM customers2

LOAD DATA INFILE 'c:\mysql\out.csv' INTO TABLE customers2;

# 将数据导入空表

SELECT * FROM customers2;

# 导入空表后查看

2 性能管理(索引 Index)

de354ea102a706552fff04374b4ead02.png

右键Table → 选项卡Index → 写入索引的名称,索引列字段名,索引类型和方法 → 保存

然后在 MySQL语句中加上 ‘EXPLAIN’ 即可在结果中看到 MySQL筛选过程的数据:

EXPLAIN

SELECT * FROM customers WHERE cust_id = 10004

7d5ba0aae1dbca4057bd9a84448c29f7.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值