zoukankan      html  css  js  c++  java
  • MySQL普通索引与唯一索引

    索引作用:

      提高查询效率,一般加在经常查询或者排序的字段上。

      普通索引:

        允许字段值重复

      唯一索引:

        保证数据记录唯一性

    如何选择:

      查询过程:

      • 对普通索引来说,找到满足条件的第一个记录之后,需要继续查找下一条记录,直到下一条记录不满足条件为止。
      • 对唯一索引来说,查找到第一条满足条件的数据之后,就会停止检索(唯一性)

      查询效率:

        相差不大

        • InnoDB的数据是以页(16KB大小)为单位进行读写
        • 一个数据页可以存放数千个Key
        • 普通索引通常情况下多了一次指针寻找和判断,较低概率跨数据页查找

      更新过程:

        change buffer:

        • 更新一组数据时,若数据页在内存中就直接更新;
        • 若不在内存中,更新操作缓存进change buffer中,待下一次查询访问此数据页时,读入内存,执行操作;
        • 可持久化,在内存中有拷贝,会被写入磁盘;
        • merge(将change buffer中的数据写入原数据页)的时机:
        1. 访问这个数据页
        2. 系统后台线程定期merge
        3. 数据库正常关闭(shut down)
        • 可以减少读磁盘,提高执行效率。

        若更新的目标页在内存中:

          唯一索引:

            找到插入的位置,判断有无冲突,执行更新操作

          普通索引:

            直接进行更新操作

        若数据页不在内存中:

        • 唯一索引:将数据页读入内存,判断有无冲突,插入这个值,
        • 普通索引:将更新记录在change buffer中,适合写多读少的情景,如果写完立刻又进行读操作,触发merge,增加了changebuffer的维护成本。

       结论:

      • 二者在查询效率上差别不大
      • 更新效率上有差别,普通索引可以和change buffer两两配合
      • 业务正确性优先,如果业务无法保证不会插入重复数据,并且要求数据库做约束,必须创建唯一索引

          

              

        

  • 相关阅读:
    kendo ui 查找treelist里的子控件并设置是否显示的方法
    KendoUi下的DatePicker在谷歌浏览器上不能正常显示时间的解决方法
    asp.net 第三方UI控件 Telerik KendoUI 之 TreeVIew 的用法记录
    mysql批量更新数据,即:循环select记录然后更新某一字段
    Sql语句备份Sqlserver数据库
    3des用法示例,已测试
    制作Windows服务项目详细攻略
    利用好压在C#程序里实现RAR格式的压缩和解压功能
    winform里textBox无法获得焦点的解决方案
    Shell脚本批量重命名案例
  • 原文地址:https://www.cnblogs.com/jiezai/p/12317485.html
Copyright © 2011-2022 走看看