• 索引笔记【】【】


    目录

    索引引入

    索引机制原理

    索引指令 

     创建索引

     删除索引

    修改索引

    查询索引

    创建索引练习 

    ​编辑

    小结 


    索引引入

    在查询海量的数据需要花费大量的时间,要减少响应时间,就要用到索引。 

    CREATE INDEX 索引名 on 表名(列名)-- 表示这个表的某列创造一个索引

    在创建玩索引后,该表的文件大小会变大:索引本身会占用空间

    创建索引后使用同样的查询语句进行查询,处理的速度会大大变快。

    创建索引后只对创建了索引的列的查询数据有影响,其他没创建的该慢还是慢

    索引机制原理

     

     

     比如有个学生表,在没有索引时执行查找id  = 6 的操作,会对全表进行扫描,逐条对比。

    如果创建索引,会生成一个二叉树,如上,将大大减少了查询次数,这就是索引查询数独快的原因 

    索引指令 

     

    -- 查询emp 表有没有索引 

    1. SHOW INDEXES from emp;

     创建索引

    创建索引,再次查询

    1. -- 给emp 表的empno添加一个唯一索引
    2. CREATE UNIQUE INDEX empno_index on emp(empno)

    添加普通索引的方式有两种 

    1. -- 添加普通索引方式方式1
    2. CREATE INDEX empno_index on emp(empno)、
    3. -- 添加普通索引方式2
    4. ALTER TABLE emp ADD INDEX empno_index(empno)

    添加主键索引 

    第一种是之前给某列添加主键,那就是添加了主键索引

    第二中和添加普通索引差不多,只是把index换成 primary key

    ALTER TABLE emp ADD PRIMARY KEY empno_index(empno)

     删除索引

    1. -- 删除索引
    2. -- 删除普通索引
    3. DROP INDEX empno_index on emp
    4. -- 删除主键索引
    5. ALTER TABLE emp DROP PRIMARY KEY

    修改索引

    修改索引就是先把索引删除,再添加一个新索引

    查询索引

    查询索引有三种方式

    1. -- 查询索引
    2. -- 方法1
    3. SHOW INDEX FROM emp
    4. -- 方法2
    5. SHOW INDEXES FROM emp
    6. -- 方法3
    7. SHOW KEYS FROM emp

    创建索引练习 

    1. -- 1.创建一张订单表order (id号,数量).要求id号为主键,请使
    2. -- 用2种方式来创建主键.(提示:为练习方便,可以是order1 , order2 )
    3. -- 方法1 创建表时添加主键
    4. CREATE TABLE order1 (
    5. id INT PRIMARY KEY,
    6. nums INT)
    7. -- 方法2 通过alter add添加
    8. CREATE TABLE order2(
    9. id INT,
    10. nums INT)
    11. ALTER TABLE order2 ADD PRIMARY KEY id_index(id)
    12. -- 创建一张特价菜谱表menu (id号,菜谱名,厨师,点餐人身份证,价
    13. -- 格).要求id号为主键,点餐人身份证是unique请使用两种方式来创建unique.(提示:为练习方便,可以是menu1 , menu2、
    14. -- 方法1 通过unique在创建表时添加
    15. CREATE TABLE menu1(
    16. id INT PRIMARY KEY,
    17. menu_name VARCHAR(20) NOT NULL DEFAULT '',
    18. cart_id INT UNIQUE,
    19. price INT)
    20. -- 方法2
    21. CREATE TABLE menu2(
    22. id INT PRIMARY KEY,
    23. menu_name VARCHAR(20) NOT NULL DEFAULT '',
    24. cart_id INT,
    25. price INT)
    26. CREATE UNIQUE INDEX cart_index on menu2(cart_id)

    小结 

     

     

     

     

     

  • 相关阅读:
    gitlab搭建2(linux搭建,外部windows访问,centos7)
    RANKGEN: Improving Text Generation with Large Ranking Models论文
    根据上下级关系统计数据
    HJ18 识别有效的IP地址和掩码并进行分类统计
    【软考 系统架构设计师】计算机组成与体系结构⑦ 校验码
    Linux|奇怪的知识|一次性任务at命令的使用
    02、Python 字符串
    Spring、Hibernate和Struts的整合调试(2)
    二、基础算法精讲:二分
    PromQL基础语法(下)-聚合运算符、内置函数【prometheus查询语句】
  • 原文地址:https://blog.csdn.net/hagong9/article/details/126187511