zoukankan      html  css  js  c++  java
  • MySQL 索引 总结

    1.索引的种类(六种)

      普通索引,唯一索引,全文索引,单列索引,多列索引,空间索引

    2.优缺点及注意事项

    优点:有了索引,对于记录数量很多的表,可以提高查询速度。

    缺点:索引是占用空间的,索引会影响update insert delete速度。

    以下列出几点使用mysql索引的注意事项。

      a、索引要创建在where和join用到的字段上。

      b、以下操作符号可以应用索引(:<,<=,=,>,>=,BETWEEN,IN,LIKE不以%_开头)

         以下需要注意不使用索引(<>, NOT IN, LIKE %_开头)

        <> 可以用 a>1 or a<3 代替,NOT IN 可以用NOT exists代替

      c、在使用max() min()时最好加上索引。

      d、单索引要创建在确实需要的地方。多列索引有最佳左前缀特性,所以尽量左边的字段是最常用的。

      e、索引不会包括有NULL值,就是有NULL索引就失效。

      f、使用短索引,一个字段字太多,可以建立部分索引,只取前十个字节约空间。

      g、不要在列上运算。例如:where MD5("password") = "myz"。

      h、explain select * from myz 来测试一下语句的效率...

    3.存储引擎和索引存储类型

      索引存储类型包含两种:B树型索引和HASH型索引

      MyISAM和InnoDB存储引擎支持B树型索引;MEMORY支持HASH型索引和B树型索引,默认是前者。

    4.索引的设计原则

      a.选择唯一性索引

      b.为经常需要排序,分组和联合操作的列建立索引

      c.为常需要作为查询条件的字段建立索引

      d.限制索引的数目

      e.尽量使用数据量少的字段作为索引

      f.尽量使用前缀作为索引

      g.删除不常用的或者很少用的索引

    5.创建,修改索引的SQL语句

      

    CREATE TABLE 表名(属性名 数据类型 [完整性约束条件],
                     属性名 数据类型 [完整性约束条件],
                     ......
                     [UNIQUE|FULLTEXT|SPATIAL] INDEX|KEY[别名](属性名 [(长度)] [ASC|DESC])
                     );

    实例

    普通索引创建
    CREATE TABLE index1(id INT,name VARCHAR(20),sex BOOLEAN,INDEX(id));
    
    普通索引修改
    CREATE INDEX index1_id ON index1(id);
    或
    ALTER TABLE index1 ADD INDEX index1_id(id);
    唯一性索引创建
    CREATE TABLE index2(id INT UNIQUE,name VARCHAR(20),UNIQUE INDEX index2_id(id ASC));
    
    唯一性索引修改
    CREATE UNIQUE index2_id ON index2(id);
    或
    ALTER TABLE index2 ADD UNIQUE INDEX index2_id(id);
    全文索引创建
    CREATE TABLE index3(id INT,info VARCHAR(20),FULLTEXT INDEX index3_info(info))ENGINE=MyISAM;
    
    全文索引修改
    CREATE FULLTEXT INDEX index3_info ON index3(info);
    或
    ALTER TABLE index3 ADD FULLTEXT INDEX index3_info(info);
    单列索引创建
    CREATE TABLE index4(id INT,subject VARCHAR(20),INDEX index4_st(subject(10)));
    
    单列索引修改
    CREATE INDEX index4_name ON index4(name);
    或
    ALTER TABLE index4 ADD INDEX index4_name(name);
    多列索引创建
    CREATE TABLE index5(id INT,name VARCHAR(20),sex CHAR(4),INDEX index5_ns(name,sex));
    
    多列索引修改
    CREATE INDEX index5_ns ON index5(name,sex);
    或
    ALTER TABLE index5 ADD INDEX index_ns(name,sex);
    空间索引创建
    CREATE TABLE index6(id INT,space GEOMETRY NOT NULL,SPATIAL INDEX index_sp(space))ENGINE=MyISAM;
    
    空间索引修改
    CREATE SPATIAL INDEX index6_sp ON index6(space);
    或
    ALTER TABLE index6 ADD SPATIAL INDEX index6_sp(space);

    6.删除索引

      DROP INDEX 索引名 ON 表名;

      

  • 相关阅读:
    打包时,指定war包的名称
    java读取properties文件的配置信息
    java日期时间处理集合
    jpa使用原生SQL查询数据库like的用法
    讲讲升级macOS Big Sur后的感受
    eclipse failed to create jvm The JVM shared library "/Library/Internet Plug-Ins/JavaAppletPlugin.plugin/Contents/Home/bin/../lib/server/libjvm.dylib" does not contain the JNI_CreateJavaVM symbol.
    Xcode12 占用空间过大的解决方法及彻底删除Xcode
    Entry name 'classes.dex' collided
    multidex Unable to get provider com.vivo.upgrade.library.provider.FileProvider
    android保存完了,自动关闭软键盘
  • 原文地址:https://www.cnblogs.com/xiaozong/p/5688310.html
Copyright © 2011-2022 走看看