首页 > 其他 > 详细

普通索引和唯一索引,应该怎么选择

时间:2020-03-31 18:54:27      阅读:72      评论:0      收藏:0      [点我收藏+]

 

1 查询过程
   几乎无影响
 
2 更新过程
   如果数据页在内存中,就直接更新,如果没在数据页中,就把更新纪录纪录在change buffer中,这样就不需要从磁盘中读取数据页了。下次查询的时候,读入这个数据页,然后按照change buffer进行修改
 
3 change buffer适合写多读少的业务
 
4 change buffer 减少了读磁盘的IO,redo log 减少了随机写磁盘的IO
 
 
 
是否使用唯一索引
 
首先,业务正确性优先。此文章的前提是“业务代码已经保证不会写入重复数据”的情况下,讨论性能问题。
如果业务不能保证,或者业务就是要求数据库来做约束,那么没得选,必须创建唯一索引
然后,在一些“归档库”的场景,你是可以考虑使用普通索引的。比如,线上数据只需要保留半年,然后历史数据保存在归档库。这时候,归档数据已经是确保没有唯一键冲突了。要提高归档效率,可以考虑把表里面的唯一索引改成普通索引
 
 

普通索引和唯一索引,应该怎么选择

原文:https://www.cnblogs.com/liang545621/p/12606873.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!