zoukankan      html  css  js  c++  java
  • 数据库索引

    1、创建索引:
    
    CREATE [UNIQUE] [CLUSTER] INDEX <索引名> ON <表名>(<列名>[<次序>][,<列名>[<次序>]]...);
    
    <表名>:为要建索引的基本的名字;
    
    ()中表明索引可建在该表的一列或多列上,各列名间用逗号间隔;
    
    <次序>:指定索引值的排列次序,可选ASC(升序)或DESC(降序),默认为ASC;
    
    [UNIQUE]:表明建立的索引为唯一索引;
    
    [CLUSTER]:表明创建的索引为聚簇索引;
    
    <索引名>:自己确定,尽量清晰明了。
    
    *唯一索引、聚簇索引看下方讲解。
    2、修改索引名:
    
    ALTER INDEX <旧索引名> RENAME TO <新索引名>3、删除索引:
    
    DROP INDEX <索引名>;
    
    (删除索引时,系统会同时从数据字典中删去有关该索引的描述)

    索引分类:

    一般创建三种索引:唯一索引、主键索引和聚集索引。
    1、唯一索引:
      一种索引,不允许具有索引值相同的行,从而禁止重复的索引或键值。系统在创建该索引时检查是否有重复的键值,并在每次使用 INSERT 或 UPDATE 语句添加数据时进行检查。(关键字UNIQUE)
    2、主键索引:
      主键索引是唯一索引的特定类型。该索引要求主键中的每个值都唯一。当在查询中使用主键索引时,它还允许对数据的快速访问。
    3、聚集索引:(关键字CLUSTER)
      聚集索引也称为聚簇索引(Clustered Index),聚类索引,簇集索引 。同样,非聚集索引也称为非聚簇索引,非聚类索引,非簇集索引。
    
      聚集索引确定表中数据的物理顺序。聚集索引类似于电话簿,按姓氏排列数据。由于聚集索引规定数据在表中的物理存储顺序,因此一个表只能包含一个聚集索引。但该索引可以包含多个列(组合索引),就像电话簿按姓氏和名字进行组织一样。
    
      聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此类查询的性能。同样,如果对从表中检索的数据进行排序时经常要用到某一列,则可以将该表在该列上聚集(物理排序),避免每次查询该列时都进行排序,从而节省成本。
    
      当索引值唯一时,使用聚集索引查找特定的行也很有效率。例如,使用唯一雇员 ID 列 emp_id 查找特定雇员的最快速的方法,是在 emp_id 列上创建聚集索引或 PRIMARY KEY 约束。
      (定义聚集索引键时使用的列越少越好)

    聚簇索引适用范围:

    1、含有大量非重复值的列。
    
    2、使用BETWEEN,>,>=,<或<=返回一个范围值的列
    
    3、被连续访问的列
    
    4、返回大型结果集的查询
    
    5、经常被使用连接或GROUP BY子句的查询访问的列

    下面的表总结了何时使用聚集索引或非聚集索引:

    动作描述

    使用聚集索引

    使用非聚集索引

    列经常被分组排序

    返回某范围内的数据

    不应

    一个或极少不同值

    不应

    不应

    小数目的不同值

    不应

    大数目的不同值

    不应

    频繁更新的列

    不应

    外键列

    主键列

    频繁修改索引列

    不应

    索引的优缺点:

    优点:加快对表中记录的查找或排序。 
    缺点:一是增加了数据库的存储空间;
       二是在插入和修改数据时要花费较多的时间(索引要进行相应的维护(会加重数据库的负担))。

    关系数据库管理系统在执行查询时会自动选择合适的索引作为存取路径,用户不必也不能显式地选择索引。

    索引是数据库管理系统的内部实现技术,属于内模式范畴。

    不同的关系数据库管理系统支持的索引类型不尽相同。

  • 相关阅读:
    http 请求code状态码
    uni-app实现弹窗遮罩
    小程序分享报错 Cannot read property 'apply' of null;at page XXX onShareAppMessage function
    mac下出现xcrun: error导致git、svn无法使用的解决办法
    uniapp 小程序实现自定义底部导航栏(tarbar)
    Python2.X和Python3.X中Tkinter模块的文件对话框、下拉列表的不同
    Mac 设置git的template
    每天一点点之vue框架开发
    uni-app开发小程序-使用uni.switchTab跳转后页面不刷新的问题
    小程序实现微信朋友圈时间显示效果
  • 原文地址:https://www.cnblogs.com/kangxingyue-210/p/7718465.html
Copyright © 2011-2022 走看看