关于索引

Posted lidedong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于索引相关的知识,希望对你有一定的参考价值。

索引

  索引是一种快速访问数据的途径,可提高数据库性能。索引使数据库程序无须对整个表进行扫描,就可以在其中找到所需的数据。通过建立索引能提高查询的性能。

  一般来说,select、update、delete命令的where子句性能会得到提高,但是insert(对标和索引都进行插入)、索引列update、大量数据的delete的性能会降低。

索引的分类

  逻辑分类:单列索引、组合索引、唯一索引、非唯一索引,函数索引。

  物理分类:区分索引、非分区索引、B树索引、正向索引、反向索引,位图索引。

索引的缺点:

    1、索引占用表空间,创建太多索引可能会造成索引冗余。

    2、索引会影响INSERT、UPDATE、DELETE语句的性能。

使用索引的原则:    

    1、装载数据后再建立索引。

    2、频繁搜索的列可以作为索引。

    3、在联接属性上建立索引(主外键)。

    4、经常排序分组的列。

    5、删除不经常使用的索引。

    6、指定索引块的参数,如果将来会在表上执行大量的insert操作,建立索引时设定较大的ptcfree。

    7、指定索引所在的表空间,将表和索引放在不同的表空间上可以提高性能。

    8、对大型索引,考试使用NOLOGGING子句创建大型索引。

    不要在下面的列创建索引:   

    1、仅包含几个不同值得列。

    2、表中仅包含几条记录。

以上是关于关于索引的主要内容,如果未能解决你的问题,请参考以下文章

关于SQLServer 2000 索引问题

关于MySQL索引

关于数据库的索引

MySQL——关于索引的总结

MySQL——关于索引的总结

关于index 索引