转载至:http://www.cnblogs.com/xrq730/p/5540224.html
索引
无论是面试,还是实际工作中,对于一个Java程序员来说,数据库优化是避不开的一个技术点,关于数据库的优化,在性能达不到要求的情况下,我大致给出以下几个方向:
(1)优化表结构,对常用字段和非常用的字段分开存储
(2)优化SQL,合理使用索引
(3)做数据库读写分离,减少IO压力,由于数据库对记录做了持久化并存储在磁盘上,对磁盘的I/O又是非常消耗性能的操作,因此读、写都在一个库中会大大增加I/O的压力
(4)尝试使用缓存,不要让数据都走数据库
(5)对业务做垂直拆分
(6)对表做水平拆分,这一步比较麻烦,要注意主键生成规则以及请求路由规则
以上6个点是有优先级的,本文关注的是第二点的索引部分。正确合理地使用索引对于数据库性能提升是至关重要的,本文暂时不分析索引原理,只是从实战的角度,总结一下索引的使用技巧,理论结合实践,印象会更深一些。