zoukankan      html  css  js  c++  java
  • 索引

    一   索引简介

    索引在MySQL中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构。索引对于良好的性能非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要。

    索引优化应该是对查询性能优化最有效的手段了。

    索引能够轻易将查询性能提高好几个数量级。

    索引相当于字典的音序表,如果要查某个字,如果不使用音序表,则需要从几百页中逐页去查。

    索引特点:创建与维护索引会消耗很多时间与磁盘空间,但查询速度大大提高!

    二  索引语法

    创建索引:

      --语法:

        CREATE TABLE 表名(

            字段名1  数据类型  [完整性约束条件...],

            字段名1  数据类型  [完整性约束条件...],

            [UNIQUE]  INDEX | KEY   [索引名]  (字段名[(长度)]  [ASC | DESC])

        );

      --创建普通索引示例:

        CREATE TABLE emp1(

            id  INT,

            name  VARCHAR(30),

            resume  VARCHAR(50),

            INDEX  index_emp_name(name)

            --KEY index_dept_name(name)      

        );

        --创建唯一索引示例:(就是在普通索引的前面加一个UNIQUE)

        CREATE TABLE emp2(

            id  INT,

            name  VARCHAR(30),

            bank_num  CHAR(18)  UNIQUE,

            resume  VARCHAR(50),

            UNIQUE   INDEX  index_emp1_name(name)

        );

        --创建全文索引示例:

        CREATE TABLE emp3(

            id  INT,

            name  VARCHAR(30),

            resume  VARCHAR(50),

            FULLTEXT  INDEX  index_emp3_resume(resume)

        );

        --创建多列索引示例:

        CREATE  TABLE  emp4(

        id  INT,

        name  VARCHAR(30),

        resume  VARCHAR(50),

        INDEX  index_name_resume(name,resume)

        );

    添加和删除索引:

      --添加索引:(两种方法,CREATE 和 ALTER)

        --在已经存在的表上创建索引

          CREATE  [UNIQUE]  INDEX  索引名  ON  表名(字段名[(长度)] [ASC | DESC]);

          ALTER  TABLE 表名  ADD  [UNIQUE]  INDEX  索引名(字段名[(长度)]  [ASC | DESC]);

          CREATE  INDEX  index_emp_name  on  emp1(name);

          ALTER  TABLE  emp2  ADD  UNIQUE  INDEX  index_bank_num(band_num);

      --删除索引:

        语法:DROP  INDEX  索引名  ON  表名

        DROP  INDEX  index_emp_name  ON  emp1;

        DROP  INDEX  bank_num  ON  emp2;

    三、索引测试实验:

    --创建表
    create table Indexdb.t1(id int,name varchar(20));
    
    --存储过程
    
    delimiter $$
    create procedure autoinsert() 
    BEGIN
    declare i int default 1;
    while(i<500000)do
    insert into Indexdb.t1 values(i,'yuan');
    set i=i+1;
    end while;
    END$$
    
    delimiter ;
    
    --调用函数
    call autoinsert();
    
    -- 花费时间比较:
    -- 创建索引前
       select * from Indexdb.t1 where id=300000;--0.32s
    -- 添加索引 
       create index index_id on Indexdb.t1(id);
    -- 创建索引后
       select * from Indexdb.t1 where id=300000;--0.00s
  • 相关阅读:
    项目总结—校园办公管理系统(SSM框架搭建)
    sssp-webservce_restful
    angular 中怎么获取路径上的参数 参考:https://docs.angularjs.org/api/ng/service/$location
    spring mvc 解决json 不能转换的问题
    在 html中怎么获取中的参数
    弹框,图标
    sssp maven pom
    spring中 的MD5 加密
    angularjs 整合 bootstrap
    深入理解Java包装类与自动拆装箱
  • 原文地址:https://www.cnblogs.com/guomeina/p/7252373.html
Copyright © 2011-2022 走看看