mysql数据库当表 比较多时候会比较影响效率,优化就变得很重要了。
1.优化运行慢的sql和建立索引
索引的建立会很大程度的加快查询效率,但是索引的建立也要注意:
1.索引不能储存null值(联合索引不全为null)
2.建立索引字段重复值要少
3.sql中有or 会使索引失效
4.like '%xxx%'也会使索引失效可用 like ‘xx%’
5.not in 用 not exists 代替 <>用 大于小于代替
2.使用主从数据库
使用主从数据库,实现读写分离
3.使用缓存技术
使用缓存来保存使用较多信息 如 用户信息等,常见的如memcached,redis等
4.垂直拆分
垂直拆分表的记录并不多,但是字段却很长,表占用空间很大,检索表的时候需要执行大量的IO,严重降低了性能。这时需要把大的字段拆分到另一个表,并且该表与原表是一对一的关系。
例如:文章表中 文章标题和内容 内容会占据比较大,当我们只查询标题时候,内容也会被扫码,严重影响效率,我们垂直拆分,将标题和内容拆分开,分别放在不同服务器,建立一对一关系。
5.水平拆分
将表进行拆分,如拆分 1...100表 当用户查询时候 用户%100,得到的值 去查询相应的表