数据库的优化

本文讨论了SQL语句执行慢的分析方法,包括使用explain执行计划检查索引,避免回表操作和join优化。还介绍了索引的概念、底层数据结构以及创建原则,探讨了索引失效的情况,并分享了作者在SQL优化中的经验和技巧,如合理选择数据库表字段类型和利用主从复制等技术提升性能。
摘要由CSDN通过智能技术生成

1.sql语句执行的很慢,如何分析

使用explain执行计划来查询sql语句是否使用到了索引,如果没有,是不是没创建索引,没创建就去创建,创建了但没有到索引是不是语法上的问题导致索引失效,如果是就需要重新优化sql语句。另外,检查一下是否进行了回表操作,如果有则需要调整一下查询的字段,覆盖索引查询。还有就是如果使用了多个join,看看能不能使用缓存等方法减少join的个数,重写sql语句。

2.索引概念及索引底层数据结构

索引是一种可以高效获取数据库数据的数据结构,mysql的索引底层使用的是b+树,相比b树的每个节点都存数据,b+树只有叶子节点存储数据,非叶子节点只存储索引,叶子节点通过节点连接成链表。

3.索引创建的原则

1.查询频率高的字段建立索引,2.值种类少的字段如性别只有男女不应建立索引,3.多个字段需要建立索引建议使用联合索引,4.字段值太长可以建立前缀索引,5.控制索引的数量,不需要每个字段都创建索引。

4.什么情况下索引会失效

1.使用左模糊查询like '%xx’时,2.使用联合索引但查询条件不包含联合索引的第一个字段时,3.使用联合索引范围查询右边的字段时,范围查询字段的之后字段的索引失效,4.索引列上运算,5.字段是字符串类型但查询条件没加双引号或单引号时

5.谈谈你对sql优化的经验

我觉得有以下几个方面吧。1.首先是数据库表字段的选取,要选取合适的类型,比如一个状态值只有有限的个位数取值,可以使用tinyint而不是int,这样可以节省内存,提高查询速度。2.索引创建原则。3.sql语句优化:select所需要的字段,避免select *回表查询;join时以小表驱动大表。4.主从复制,读写分离,让写数据不影响读数据。5.当数据量到达一定量,比如单表超过1000行或者大小超过20G时,可以考虑分表分库。

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值