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


    1 查询过程
       几乎无影响
     
    2 更新过程
       如果数据页在内存中,就直接更新,如果没在数据页中,就把更新纪录纪录在change buffer中,这样就不需要从磁盘中读取数据页了。下次查询的时候,读入这个数据页,然后按照change buffer进行修改
     
    3 change buffer适合写多读少的业务
     
    4 change buffer 减少了读磁盘的IO,redo log 减少了随机写磁盘的IO
     
     
     
    是否使用唯一索引
     
    首先,业务正确性优先。此文章的前提是“业务代码已经保证不会写入重复数据”的情况下,讨论性能问题。
    如果业务不能保证,或者业务就是要求数据库来做约束,那么没得选,必须创建唯一索引
    然后,在一些“归档库”的场景,你是可以考虑使用普通索引的。比如,线上数据只需要保留半年,然后历史数据保存在归档库。这时候,归档数据已经是确保没有唯一键冲突了。要提高归档效率,可以考虑把表里面的唯一索引改成普通索引
     
     
  • 相关阅读:
    关于flume配置加载
    ListMultimap 容器
    HotSpotOverview.pdf
    芝麻西瓜
    念念不忘必有回响
    phpstrom代码格式化
    小总结
    Redis支持的数据类型
    如何通过phpstorm查看某一行代码的变更记录
    mysql自动添加时间
  • 原文地址:https://www.cnblogs.com/liang545621/p/12606873.html
Copyright © 2020-2023  润新知