每日积累(二一)--mysql 数据库优化

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,得到的值 去查询相应的表

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值