索引就是加快检索表中数据的方法。数据库的索引类似于书籍的索引。在书籍中,索引允许用户不必翻阅完整个书就能迅速地找到所需要的信息。在数据库中,索引也允许数据库程序迅速地找到表中的数据,而不必扫描整个数据库。
索引是对数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息。是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。
索引有三种类型:
唯一索引:唯一索引是不允许其中任何两行具有相同索引值的索引。当现有数据中存在重复的键值时,大多数数据库不允许将新创建的唯一索引与表一起保存。
主键索引:数据库表经常有一列或多列组合,其值唯一标识表中的每一行。该列称为表的主键。在数据库关系图中为表定义主键将自动创建主键索引,主键索引是唯一索引的特定类型。该索引要求主键中的每个值都唯一。
聚焦索引:在聚集索引中,表中行的物理顺序与键值的逻辑(索引)顺序相同。一个表只能包含一个聚集索引。如果某索引不是聚集索引,则表中行的物理顺序与键值的逻辑顺序不匹配。
扩展资料:
通过建立索引可以极大地提高在数据库中获取所需信息的速度,同时还能提高服务器处理相关搜索请求的效率,从这个方面来看它具有以下优点:
在设计数据库时,通过创建一个惟一的索引,能够在索引和信息之间形成一对一的映射式的对应关系,增加数据的惟一性特点。
能提高数据的搜索及检索速度,符合数据库建立的初衷。
能够加快表与表之间的连接速度,这对于提高数据的参考完整性方面具有重要作用。
在信息检索过程中,若使用分组及排序子句进行时,通过建立索引能有效的减少检索过程中所需的分组及排序时间,提高检索效率。
建立索引之后,在信息查询过程中可以使用优化隐藏器,这对于提高整个信息检索系统的性能具有重要意义。
参考资料:
索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。索引的作用相当于图书的目录,可以根据目录中的页码快速找到所需的内容。
一个索引是存储的表中一个特定列的值数据结构(最常见的是B-Tree,还有哈希表索引和R-tree)。索引是在表的列上创建。所以,要记住的关键点是索引包含一个表中列的值,并且这些值存储在一个数据结构中。请记住记住这一点:索引是一种数据结构
使用索引的全部意义就是通过缩小一张表中需要查询的记录(行)的数目来加快搜索的速度。
假设有一张学生名单表,有一百条数据。要查询其中名字为 小明 的学生。
一般采取select from students where name ='小明';由于我们想要得到每一个名字为小明的学生信息,在查询到第一个符合条件的行后,不能停止查询,因为可能还有其他符合条件的行。所以,必须一行一行的查找直到最后一行-这就意味数据库不得不检查上千行数据才能找到所以名字为小明 的学生。这就是所谓的全表扫描。
假设我们在 name这一列上创建一个B-Tree索引。当我们用SQL查找名字是‘小明 ’的学生时,不需要再扫描全表。而是用索引查找去查找名字为‘小明 ’的学生,因为索引已经按照按字母顺序排序。索引已经排序意味着查询一个名字会快很多,因为名字首字母为‘小’的学生都是排列在一起的。另外重要的一点是,索引同时存储了表中相应行的指针以获取其他列的数据。
索引是对数据库表中一列或多列的值进行排序的一种结构,例如 employee 表的姓(name)列如果要按姓查找特定职员,与必须搜索表中的所有行相比,索引会帮助您更快地获得该信息
索引是一个单独的、物理的数据库结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序数据库使用索引的方式与您使用书籍中的索引的方式很相似:它搜索索引以找到特定值,然后顺指针找到包含该值的行在数据库关系图中,您可以在选定表的“索引/键”属性页中创建、编辑或删除每个索引类型当保存索引所附加到的表,或保存该表所在的关系图时,索引将保存在数据库中
可以基于数据库表中的单列或多列创建索引多列索引使您可以区分其中一列可能有相同值的行如果经常同时搜索两列或多列或按两列或多列排序时,索引也很有帮助例如,如果经常在同一查询中为姓和名两列设置判据,那么在这两列上创建多列索引将很有意义确定索引的有效性:检查查询的 WHERE 和 JOIN 子句在任一子句中包括的每一列都是索引可以选择的对象对新索引进行试验以检查它对运行查询性能的影响考虑已在表上创建的索引数量最好避免在单个表上有很多索引检查已在表上创建的索引的定义最好避免包含共享列的重叠索引检查某列中唯一数据值的数量,并将该数量与表中的行数进行比较比较的结果就是该列的可选择性,这有助于确定该列是否适合建立索引,如果适合,确定索引的类型
建立索引的优点:
1大大加快数据的检索速度;
2创建唯一性索引,保证数据库表中每一行数据的唯一性;
3加速表和表之间的连接;
4在使用分组和排序子句进行数据检索时,可以显著减少查询中分组和排序的时间
索引类型:
根据数据库的功能,可以在数据库设计器中创建四种索引:唯一索引、非唯一索引、主键索引和聚集索引尽管唯一索引有助于定位信息,但为获得最佳性能结果,建议改用主键或唯一约束
唯一索引:
唯一索引是不允许其中任何两行具有相同索引值的索引当现有数据中存在重复的键值时,大多数数据库不允许将新创建的唯一索引与表一起保存数据库还可能防止添加将在表中创建重复键值的新数据例如,如果在 employee 表中职员的姓 (lname) 上创建了唯一索引,则任何两个员工都不能同姓
非唯一索引:
非唯一索引是相对唯一索引,允许其中任何两行具有相同索引值的索引当现有数据中存在重复的键值时,数据库是允许将新创建的索引与表一起保存这时数据库不能防止添加将在表中创建重复键值的新数据
主键索引:
数据库表经常有一列或列组合,其值唯一标识表中的每一行该列称为表的主键在数据库关系图中为表定义主键将自动创建主键索引,主键索引是唯一索引的特定类型该索引要求主键中的每个值都唯一当在查询中使用主键索引时,它还允许对数据的快速访问
聚集索引(也叫聚簇索引):
在聚集索引中,表中行的物理顺序与键值的逻辑(索引)顺序相同一个表只能包含一个聚集索引如果某索引不是聚集索引,则表中行的物理顺序与键值的逻辑顺序不匹配与非聚集索引相比,聚集索引通常提供更快的数据访问速度
以上就是关于数据库中的索引是什么意思全部的内容,包括:数据库中的索引是什么意思、什么是索引索引类型有几种,各有什么特点、数据库中的索引是什么意思有什么用途等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)