精华内容
下载资源
问答
  • 创建索引可以大大提高系统的性能优点:第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。第二,可以大大加快数据的检索速度,这也是创建索引的最主要的原因。第三,可以加速表表之间的连接,特别...

    创建索引可以大大提高系统的性能

    优点:

    第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。

    第二,可以大大加快数据的检索速度,这也是创建索引的最主要的原因。

    第三,可以加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。

    第四,在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。

    第五,通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能。 

    缺点:

    第一,创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。

    第二,索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大。

    第三,当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。 


    展开全文
  • 这是因为,创建索引可以大大提高系统的性能,优点: 第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 第二,可以大大加快数据的检索速度,这也是创建索引的最主要的原因。 第三,可以加速表...

    数据库中索引的优缺点
    为什么要创建索引呢?这是因为,创建索引可以大大提高系统的性能,优点:
    第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。
    第二,可以大大加快数据的检索速度,这也是创建索引的最主要的原因。
    第三,可以加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。
    第四,在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。
    第五,通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能。

    也许会有人要问:增加索引有如此多的优点,为什么不对表中的每一个列创建一个索引呢?
    这种想法固然有其合理性,然而也有其片面性。虽然,索引有许多优点,但是,为表中的每一个列都增加索引,是非常不明智的。
    这是因为,增加索引也有许多不利的一个方面, 缺点:
    第一,创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。
    第二,索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间
    就会更大。
    第三,当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。

    索引是建立在数据库表中的某些列的上面。因此,在创建索引的时候,应该仔细考虑在哪些列上可以创建索引,在哪些列上不能创建索
    引。一般来说,应该在这些列上创建索引,
    例如:在经常需要搜索的列上,可以加快搜索的速度;
    在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构;
    在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度;
    在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的;
    在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间;
    在经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。

    同样,对于有些列不应该创建索引。一般来说,不应该创建索引的的这些列具有下列特点:
    第一,对于那些在查询中很少使用或者参考的列不应该创建索引。这是因为,既然这些列很少使用到,因此有索引或者无索引,
    并不能提高查询速度。相反,由于增加了索引,反而降低了系统的维护速度和增大了空间需求。
    第二,对于那些只有很少数据值的列也不应该增加索引。这是因为,由于这些列的取值很少,例如人事表的性别列,
    在查询的结果中,结果集的数据行占了表中数据行的很大比例,即需要在表中搜索的数据行的比例很大。增加索引,
    并不能明显加快检索速度。第三,对于那些定义为text, image和bit数据类型的列不应该增加索引。这是因为,这些列的数据量要么
    相当大,要么取值很少。第四,当修改性能远远大于检索性能时,不应该创建索引。这是因为,修改性能和检索性能是互相矛盾的。
    当增加索引时,会提高检索性能,但是会降低修改性能。当减少索引时,会提高修改性能,降低检索性能。因此,当修改性能远远大
    于检索性能时,不应该创建索引。

    展开全文
  • 索引优点和缺点

    2012-11-30 15:18:40
    一、索引的概念 索引就是加快检索表中数据的方法。数据库的索引类似于书籍的索引。在书籍中,索引允许用户不必翻阅完整个书就能迅速地找到所需要的信息。在数据库中,索引也允许...索引创建在表上,不能创建在视图

    一、索引的概念

    索引就是加快检索表中数据的方法。数据库的索引类似于书籍的索引。在书籍中,索引允许用户不必翻阅完整个书就能迅速地找到所需要的信息。在数据库中,索引也允许数据库程序迅速地找到表中的数据,而不必扫描整个数据库。

    二、索引的特点

         1.索引可以加快数据库的检索速度

         2.索引降低了数据库插入、修改、删除等维护任务的速度

         3.索引创建在表上,不能创建在视图上

         4.索引既可以直接创建,也可以间接创建

         5.可以在优化隐藏中,使用索引

         6.使用查询处理器执行SQL语句,在一个表上,一次只能使用一个索引

    三、索引的优点

      1.创建唯一性索引,保证数据库表中每一行数据的唯一性

          2.大大加快数据的检索速度,这也是创建索引的最主要的原因

      3.加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。

      4.在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。

      5.通过使用索引,可以在查询的过程中使用优化隐藏器,提高系统的性能。

    四、索引的缺点

      1.创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加

      2.索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大

      3.当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,降低了数据的维护速度

    五、索引分类

      1.直接创建索引和间接创建索引

        直接创建索引: CREATE INDEX mycolumn_index ON mytable (myclumn)

        间接创建索引:  定义主键约束或者唯一性键约束,可以间接创建索引

         2.普通索引和唯一性索引

        普通索引:

            CREATE INDEX mycolumn_index ON mytable (myclumn)

        唯一性索引:保证在索引列中的全部数据是唯一的,对聚簇索引和非聚簇索引都可以使用

                  CREATE UNIQUE COUSTERED INDEX myclumn_cindex ON mytable(mycolumn)

         3.单个索引和复合索引

        单个索引:即非复合索引

        复合索引:又叫组合索引,在索引建立语句中同时包含多个字段名,最多16个字段

            CREATE INDEX name_index ON username(firstname,lastname)

      4.聚簇索引和非聚簇索引(聚集索引,群集索引)

        聚簇索引:物理索引,与基表的物理顺序相同,数据值的顺序总是按照顺序排列

            CREATE CLUSTERED INDEX mycolumn_cindex ON mytable(mycolumn) WITH

            ALLOW_DUP_ROW(允许有重复记录的聚簇索引)

        非聚簇索引:

            CREATE UNCLUSTERED INDEX mycolumn_cindex ON mytable(mycolumn)

    六、索引的使用

         1.当字段数据更新频率较低,查询使用频率较高并且存在大量重复值是建议使用聚簇索引

         2.经常同时存取多列,且每列都含有重复值可考虑建立组合索引

         3.复合索引的前导列一定好控制好,否则无法起到索引的效果。如果查询时前导列不在查询条件中则该复合索引不会被使用。前导列一定是使用最频繁的列

      4.多表操作在被实际执行前,查询优化器会根据连接条件,列出几组可能的连接方案并从中找出系统开销最小的最佳方案。连接条件要充份考虑带有索引的表、行数多的表;内                           外表的选择可由公式:外层表中的匹配行数*内层表中每一次查找的次数确定,乘积最小为最佳方案

      5.where子句中对列的任何操作结果都是在sql运行时逐列计算得到的,因此它不得不进行表搜索,而没有使用该列上面的索引;如果这些结果在查询编译时就能得到,那么就可以被sql优化器优化,使用索引,避免表搜索。

        例:select * from record where substring(card_no,1,4)=’5378’
                    && select * from record where card_no like ’5378%’

        任何对列的操作都将导致表扫描,它包括数据库函数、计算表达式等等,查询时要尽可能将操作移至等号右边

      6.where条件中的’in’在逻辑上相当于’or’,所以语法分析器会将in ('0','1')转化为column='0' or column='1'来执行。我们期望它会根据每个or子句分别查找,再将结果相加,这样可以利用column上的索引;但实际上它却采用了"or策略",即先取出满足每个or子句的行,存入临时数据库的工作表中,再建立唯一索引以去掉重复行,最后从这个临时表中计算结果。因此,实际过程没有利用column上索引,并且完成时间还要受tempdb数据库性能的影响。in、or子句常会使用工作表,使索引失效;如果不产生大量重复值,可以考虑把子句拆开;拆开的子句中应该包含索引

    展开全文
  • 索引优点和缺点

    万次阅读 2018-07-26 11:05:22
    索引的优点和缺点 一、为什么要创建索引呢(优点)? 这是因为,创建索引可以大大提高系统的性能。 第一, 通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 第二, 可以大大加快数据的检索速度,这...

    加菲猫

    Just have a little faith.

    索引的优点和缺点

    一、为什么要创建索引呢(优点)?
    这是因为,创建索引可以大大提高系统的性能。
    第一,   通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。
    第二,   可以大大加快数据的检索速度,这也是创建索引的最主要的原因。
    第三,   可以加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。
    第四,   在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。
    第五,   通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能。

    二、建立方向索引的不利因素(缺点)
    也许会有人要问:增加索引有如此多的优点,为什么不对表中的每一个列创建一个索引呢?这种想法固然有其合理性,然而也有其片面性。虽然,索引有许多优点,但是,为表中的每一个列都增加索引,是非常不明智的。这是因为,增加索引也有许多不利的一个方面。

    第一,   创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。
    第二,   索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大。
    第三,   当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。

    三、创建方向索引的准则
    索引是建立在数据库表中的某些列的上面。因此,在创建索引的时候,应该仔细考虑在哪些列上可以创建索引,在哪些列上不能创建索引。
    一般来说,应该在这些列上创建索引。
    第一,   在经常需要搜索的列上,可以加快搜索的速度;
    第二,   在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构;
    第三,   在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度;
    第四,   在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的;
    第五,   在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间;
    第六,   在经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。

    同样,对于有些列不应该创建索引。一般来说,不应该创建索引的的这些列具有下列特点:
    第一,             对于那些在查询中很少使用或者参考的列不应该创建索引。这是因为,既然这些列很少使用到,因此有索引或者无索引,并不能提高查询速度。相反,由于增加了索引,反而降低了系统的维护速度和增大了空间需求。
    第二,             对于那些只有很少数据值的列也不应该增加索引。这是因为,由于这些列的取值很少,例如人事表的性别列,在查询的结果中,结果集的数据行占了表中数据行的很大比例,即需要在表中搜索的数据行的比例很大。增加索引,并不能明显加快检索速度。
    第三,             对于那些定义为text, image和bit数据类型的列不应该增加索引。这是因为,这些列的数据量要么相当大,要么取值很少。
    第四,             当修改性能远远大于检索性能时,不应该创建索引。这是因为,修改性能和检索性能是互相矛盾的。当增加索引时,会提高检索性能,但是会降低修改性能。当减少索引时,会提高修改性能,降低检索性能。因此,当修改性能远远大于检索性能时,不应该创建索引。

    展开全文
  • MySQL建立索引优点和缺点

    千次阅读 2018-04-15 21:59:40
    建立索引的优缺点:为什么要创建索引呢? 这是因为,创建索引可以大大提高系统的性能。 第一、通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 第二、可以大大加快 数据的检索速度,这也是创建索引的...
  • 数据库 索引优点和缺点

    千次阅读 2019-04-12 20:29:42
    为什么要创建索引呢?这是因为,创建索引可以大大提高系统的性能。 第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 第二,可以大大加快 数据的检索速度,这也是创建索引的最主要的原因。 ...
  • 数据库使用索引优点是提高查询效率,缺点是对于时间资源消耗较大
  • 数据库索引的作用优点和缺点

    万次阅读 多人点赞 2016-09-13 17:10:04
    为什么要创建索引呢?这是因为,创建索引可以大大提高系统的性能。 第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 第二,可以大大加快 数据的检索速度,这也是创建索引的最主要的原因。 第三...
  • 为什么要创建索引呢?这是因为,创建索引可以大大提高系统的性能。  第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。  第二,可以大大加快 数据的检索速度,这也是创建索引的最主要的原因。...
  • 索引优点缺点

    千次阅读 2010-06-09 21:58:00
    第二, 可以大大加快数据的检索速度,这也是创建索引的最主要的原因。 第三, 可以加速表表之间的连接,特别是在实现数据的参考完整性方面特别有意义。 第四, 在使用分组排序子句进行数据检索时,同样可以...
  • 以下的文章主要是对Oracle数据库索引优点缺点的介绍,如果你对Oracle数据库索引优点缺点想有所了解的话,你可以通过以下的文章对其的实际应用与功能有所了解,以下是文章的具体介绍。  数据库的索引分为...
  • 一、为什么要创建索引呢(优点)? 这是因为,创建索引可以大大提高系统的性能。 第一, 通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 第二, 可以大大加快数据的检索速度,这也是创建索引的最...
  • 数据库索引的作用和优点缺点以及索引的11中用法
  • 为什么要创建索引呢?这是因为,创建索引可以大大提高系统的性能。第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。第二,可以大大加快数据的检索速度,这也是创建索引的最主要的原因。第三,可以...
  • 数据库索引优点缺点

    千次阅读 2015-11-18 23:05:32
    索引是对数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息。 数据库索引 什么是索引  数据库索引好比是一本书前面的目录,能加快数据库的查询速度。  例如这样一个...
  • 索引是快速搜索的关键。MySQL索引的建立对于MySQL的高效运行是很重要的。...假如我们创建了一个 mytable表: CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL ); 我们随机向里面插入了1000
  • 索引虽然优点非常多,但也不是越多越好,增加索引的同时也会带来一些负面的影响 第一,创建索引和维护索引要耗费时间,这种时间随着数据 量的增加而增加。 第二,索引需要占物理空间,除了数据表占数据空间之外,每...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 83,223
精华内容 33,289
关键字:

创建索引的优点和缺点