zoukankan      html  css  js  c++  java
  • 索引

    索引
    可以利用索引快速访问数据库表中的特定信息。索引是对数据库表中一个或多个列(例如,employee   表的姓氏   (lname)   列)的值进行排序的结构。如果想按特定职员的姓来查找他或她,则与在表中搜索所有的行相比,索引有助于更快地获取信息。
    索引提供指针以指向存储在表中指定列的数据值,然后根据指定的排序次序排列这些指针。数据库使用索引的方式与使用书的目录很相似:通过搜索索引找到特定的值,然后跟随指针到达包含该值的行。
    在数据库关系图中,可以为选定的表创建、编辑或删除索引/键属性页中的每个索引类型。当保存附加在此索引上的表或包含此表的数据库关系图时,索引同时被保存。有关详细信息,请参见创建索引。
    通常情况下,只有当经常查询索引列中的数据时,才需要在表上创建索引。索引将占用磁盘空间,并且降低添加、删除和更新行的速度。不过在多数情况下,索引所 带来的数据检索速度的优势大大超过它的不足之处。然而,如果应用程序非常频繁地更新数据,或磁盘空间有限,那么最好限制索引的数量。

    索引类型
    根据数据库的功能,可在数据库设计器中创建三种类型的索引   —   唯一索引、主键索引和聚集索引。
    提示       尽管唯一索引有助于找到信息,但为了获得最佳性能,建议使用主键约束或唯一约束。
    唯一索引
    唯一索引不允许两行具有相同的索引值。
    主键索引
    数据库表通常有一列或列组合,其值用来唯一标识表中的每一行。该列称为表的主键。
    在数据库关系图中为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。
    聚集索引
    聚集索引中,表中各行的物理顺序与键值的逻辑(索引)顺序相同。表只能包含一个聚集索引。
    如果不是聚集索引,表中各行的物理顺序与键值的逻辑顺序不匹配。聚集索引比非聚集索引有更快的数据访问速度
    在   Microsoft?   SQL   Server?   数据库中可以创建聚集索引。在聚集索引中,表中各行的物理顺序与索引键值的逻辑(索引)顺序相同。表只能包含一个聚集索引。聚集索引通常可加快   UPDATE   和   DELETE   操作的速度,因为这两个操作需要读取大量的数据。创建或修改聚集索引可能要花很长时间,因为执行这两个操作时要在磁盘上对表的行进行重组。
    可考虑将聚集索引用于:  
    1:包含数量有限的唯一值的列,如   state   列只包含   50   个唯一的州代码。
    2:使用下列运算符返回一个范围值的查询:BETWEEN、> 、> =、 <   和   <=。
    3:返回大结果集的查询。   (摘自Microsoft?   SQL   Server?帮助)
    聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行 的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此 类查询的性能。同样,如果对从表中检索的数据进行排序时经常要用到某一列,则可以将该表在该列上聚集(物理排序),避免每次查询该列时都进行排序,从而节 省成本。
    当索引值唯一时,使用聚集索引查找特定的行也很有效率。例如,使用唯一雇员   ID   列   emp_id   查找特定雇员的最快速的方法,是在   emp_id   列上创建聚集索引或   PRIMARY   KEY   约束。
    在创建聚集索引之前,应先了解您的数据是如何被访问的。可考虑将聚集索引用于:  
    1   包含大量非重复值的列。
    2   使用下列运算符返回一个范围值的查询:BETWEEN、> 、> =、 <   和   <=。
    3   被连续访问的列。
    4   返回大型结果集的查询。
    5   经常被使用联接或   GROUP   BY   子句的查询访问的列;一般来说,这些是外键列。对   ORDER   BY   或   GROUP   BY   子句中指定的列进行索引,可以使   SQL   Server   不必对数据进行排序,因为这些行已经排序。这样可以提高查询性能。
    6   OLTP   类型的应用程序,这些程序要求进行非常快速的单行查找(一般通过主键)。应在主键上创建聚集索引。  
    聚集索引不适用于:  
    1   频繁更改的列   这将导致整行移动(因为   SQL   Server   必须按物理顺序保留行中的数据值)。这一点要特别注意,因为在大数据量事务处理系统中数据是易失的。
    2   宽键     来自聚集索引的键值由所有非聚集索引作为查找键使用,因此存储在每个非聚集索引的叶条目内。
    说明
    如果该表上尚未创建聚集索引,且在创建   PRIMARY   KEY   约束时未指定非聚集索引,PRIMARY   KEY   约束会自动创建聚集索引。
    注意事项
    定义聚集索引键时使用的列越少越好,这一点很重要。如果定义了一个大型的聚集索引键,则同一个表上定义的任何非聚集索引都将增大许多,因为非聚集索引条目包含聚集键。当把   SQL   脚本保存到可用空间不足的磁盘上时,索引优化向导不返回错误。

    以下整理自网络:http://zhidao.baidu.com/question/33413925.html

    /*
    创建简单的非聚集索引
    */
    USE ZHANGXU
    GO
    if exists(select name from sys.indexes where name = N'IX_ID_NAME')
    DROP INDEX IX_ID_NAME on worker
    go--检查是否存在索引,有则删除索引
    create index IX_ID_NAME--创建索引
    on worker(w_id,w_name)--在ID NAME 两个字段上创建非聚集索引
    drop index worker.IX_ID_NAME--删除索引
    select *from sys.indexes where name = 'IX_ID_NAME'--查看索引
    /*
    创建唯一非聚集索引
    */
    USE ZHANGXU
    GO
    IF EXISTS(SELECT NAME FROM SYS.INDEXES WHERE NAME = N'IX_W_NAME')
    DROP INDEX IX_W_NAME ON WORKER
    GO
    CREATE UNIQUE INDEX IX_W_NAME--唯一非聚集索引
    ON WORKER(W_NAME)
    /*
    查看索引T-SQL脚本
    */
    --IX_W_NAME 唯一 非聚集索引
    USE [zhangxu]
    GO
    /****** 对象:  Index [IX_W_NAME]    脚本日期: 07/29/2007 16:54:53 ******/
    CREATE UNIQUE NONCLUSTERED INDEX [IX_W_NAME] ON [dbo].[worker] 
    (
     [w_name] ASC
    )
    WITH 
    (
    SORT_IN_TEMPDB = OFF, 
    DROP_EXISTING = OFF, 
    IGNORE_DUP_KEY = OFF, 
    ONLINE = OFF
    ) 
    ON [PRIMARY]
    
    --PK_W_ID聚集索引
    USE [zhangxu]
    GO
    /****** 对象:  Index [PK_W_ID]    脚本日期: 07/29/2007 16:56:45 ******/
    ALTER TABLE [dbo].[worker] 
    ADD  CONSTRAINT [PK_W_ID] PRIMARY KEY CLUSTERED 
    (
     [w_id] ASC
    )
    WITH 
    (
    SORT_IN_TEMPDB = OFF, 
    IGNORE_DUP_KEY = OFF, 
    ONLINE = OFF
    ) ON [PRIMARY]
    
    --UQ_WORKER 唯一,非聚集索引
    USE [zhangxu]
    GO
    /****** 对象:  Index [UQ__worker__07020F21]    脚本日期: 07/29/2007 16:58:38 ******/
    ALTER TABLE [dbo].[worker] 
    ADD UNIQUE NONCLUSTERED 
    (
     [w_name] ASC
    )
    WITH 
    (SORT_IN_TEMPDB = OFF, 
    IGNORE_DUP_KEY = OFF, 
    ONLINE = OFF
    ) ON [PRIMARY]
    select *from worker
    insert into worker(w_name,w_age,w_pay) values('王国龙',25,4500)
  • 相关阅读:
    【Python】表白代码
    有关加密技术的概述,黑客是如何破解加密数据?
    Kali Linux的发展史,专为数字取证和渗透测试而设计
    在Wi-Fi路由器中发现了新的安全漏洞
    太可怕!看看黑客是怎样利用社会工程学窃取你的密码?
    不可不知!未来警惕被黑客植入微芯片
    什么是计算机漏洞,为什么会有漏洞呢?
    揭秘人工智能将如何影响今天的工作
    Linux为程序员添加了行为准则
    不可不知!4种常见的黑客攻击手段
  • 原文地址:https://www.cnblogs.com/zerocc/p/2266539.html
Copyright © 2011-2022 走看看