mysql优化场景,实战经验:MySql的2个优化技巧(场景分析、3步使用详解)

(1)利用PROCEDURE ANALYSE()优化表的数据类型

1)场景分析

有时候,我们在定义表的字段类型,或者长度的时候,不确定应该给出多长,因而,导致实际操作中会将长度定义的有冗余,这样会造成浪费。而PROCEDURE ANALYSE()语句就是通过分析表的数据,给出优化建议。

2)具体使用步骤

第一步:执行如下命令:

select * from `person` PROCEDURE ANALYSE();

第二步:结果展示为:

25ac4f6b11ff60c40676b86bf2939578.png

第三步:分析结果

比如第二行的结果可以看出:personnameMax_length为22.但是此表开始设置时是45,这样可以针对此字段的长度进行优化

第四步:利用alert 对表进行优化。

alter table person modify personname varchar(30);

(2)利用中间表提高统计查询的效率

1)场景分析

如果我们有一张关于客户的表,数据量非常大千万级别,而且是在线上运行的数据库实例中的表。此时我们需要进行统计查询,如果直接查询不但会对线上的表造成负面影响,而且效率不太高

2)利用中间表解决的办法

第一步:建立一张表结构跟目标表一样的临时表,这里以person表举例,建立临时表如下:

create table temp_person(

id int(11),

personname varchar(45),

age int(11),

sex int(1)

);

第二步:将要查询的数据转移到中间表中

insert into temp_person select * from person where sex = 1;

第三步:基于中间表进行查询

select sum(age) from person;

e6b31e621a5f814315eb60ac6d8d181d.png

本文仅代表作者个人观点,不代表SEO研究协会网官方发声,对观点有疑义请先联系作者本人进行修改,若内容非法请联系平台管理员,邮箱cxb5918@163.com。更多相关资讯,请到SEO研究协会网www.seoxiehui.cn学习互联网营销技术请到巨推学院www.jutuiedu.com。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值