数据库优化思路
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),可不选择优化,优化效果不明显。