zoukankan      html  css  js  c++  java
  • mysql 索引学习的一些总结

    一、使用索引的注意事项 

      1、索引不会包含有NULL值的列 (数据库设计时不要让字段的默认值为NULL )。

      2、使用短索引:对串列进行索引,如果可能应该指定一个前缀长度,前10个或20个字符内 ;使用短索引可以大量节省磁盘空间,也有可能会使查询更快;较小的索引涉及的磁盘I/O较少,较短的值比较起来更快;对于较短的键值,索引高速缓存中块能容纳更多的键值,因此MySql也可以内存中容纳更多的值。这增加了为了读到行而不用读取索引中较多块的可能性。

      3、 索引列排序 : MySQL查询只使用一个索引因此如果where子句中已经使用了索引的话,那么order by中的列是不会使用索引的。因此数据库默认排序可以符合要求的情况下不要使用排序操作;尽量不要包含多个列的排序,如果需要最好给这些列创建复合索引。

          4、利用最左前缀:在创建一个n列索引时,实际是创建了MySql可利用的n个索引,多列索引可起几个索引的作用,因为可利用索引最左边的列集来匹配。

              假设现在我们有一个firstname、lastname、age列上的多列索引,我们称这个索引为fname_lname_age。当搜索条件是以下各种列的组合时,MySQL将使用fname_lname_age索引:

        firstname,lastname,age 

        firstname,lastname 

        firstname

      5、不要过度索引:过度索引会占用过多的磁盘空间,并降低写操作性能。在修改表的内容时,必须对索引进行更新,有时有可能需要进行重构,因此,过多的索引,更新所花的时间越长。索引太多也可能会导致MySql找不到所要使用的最好索引。

      6、考虑在列上进行比较的类型:索引可用于“<","<=","=",">",">="">"和BETWEEN运算,在模试里有一个直接量前缀时,也可用行like运算。如果只将某列用于其他运算时(如STRCMP()),对其进行索引没有价值。

      7、   like语句操作 : like “%aaa%” 不会使用索引而like “aaa%”可以使用索引。

         不要在列上进行运算 select * from users where YEAR(adddate)<2007;  将在每个行上进行运算,这将导致索引失效而进行全表扫描 可以改写为: select * from users where adddate<‘2007-01-01’。

        不使用NOT IN和<>操作。

      8、 使你的数据尽可能小:

        尽可能地使用最有效(最小)的数据类型。MySQL有很多节省磁盘空间和内存的专业化类型。

        尽可能使用较小的整数类型使表更小。例如,MEDIUMINT经常比INT好一些,因为MEDIUMINT列使用的空间要少25%。

        如果可能,声明列为NOT NULL。它使任何事情更快而且每列可以节省一位。注意如果在应用程序中确实需要NULL,应该毫无疑问使用它,只是避免 默认地在所有列上有它。

        对于MyISAM表,如果没有任何变长列(VARCHAR、TEXT或BLOB列),使用固定尺寸的记录格式。这比较快但是不幸地可能会浪费一些空间。即使你已经用CREATE选项让  VARCHAR列ROW_FORMAT=fixed,也可以提示想使用固定长度的行。

        

     

  • 相关阅读:
    hibernate一级缓存和二级缓存的区别
    springmvc中的controller是单例的
    Java 冒泡排序
    spring mvc做上传图片,文件小于10k就不生成临时文件了
    java程序生成二维码
    MySQL调优
    根据从redis缓存的数据查询出来,在从数据库中取出所有的数据,俩个数据进行比较,去掉重复,剩下库中新插入的数据,取出新数据,然后把redis中的缓存数据清空把从数据库中查出来的所有数据放到redis缓存中
    找出list中的不同元素、删除两个list中相同的对象
    PowerDesigner如何将消失的工具栏显示出来
    Oracle基础(九) Oracle的体系结构
  • 原文地址:https://www.cnblogs.com/wuheping/p/2531055.html
Copyright © 2011-2022 走看看