数据库SQL优化

数据库优化思路
1、SQL优化、添加索引
2、数据库表结构设计优化
3、硬件优化

最简单最直接的最显著的优化方式就是SQL优化
当SQL优化不明显,则考虑添加索引(对于经常需要用到的作为关联的库表字段,要习惯性添加索引,特别是跟数据量大的表做关联或者本身数据量就很大)

SQL优化大的出发点
1、减少数据访问: 设置合理的字段类型,启用压缩,通过索引访问等减少磁盘IO
2、返回更少的数据: 只返回需要的字段和数据分页处理 减少磁盘io及网络io
3、减少交互次数: 批量DML操作,函数存储等减少数据连接次数
4、减少服务器CPU开销: 尽量减少数据库排序操作以及全表查询,减少cpu 内存占用
5、利用更多资源: 使用表分区,可以增加并行操作,更大限度利用cpu资源

SQL优化
1、 尽量避免%开头,会导致数据库引擎放弃索引进行全表扫描。如下:

SELECT * FROM a WHERE b LIKE '%匹配%'

优化方式:尽量在字段后面使用模糊查询。如下:

SELECT * FROM a WHERE b LIKE '匹配%'

若必须使用,则选择一下几种方法
1、使用MySQL内置函数INSTR(str,substr) 来匹配,作用类似于java中的indexOf(),查询字符串出现的角标位置
2、使用FullText全文索引,用match against 检索
3、数据量较大的情况,建议引用ElasticSearch、solr,亿级数据量检索速度秒级
4、当表数据量较少(不超过1w),可不选择优化,优化效果不明显。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值