文章标题

来源:互联网 发布:mac怎么给srt字幕 编辑:程序博客网 时间:2024/05/03 13:27
   最近的程序出了点问题,因为数据量比较大,每次操作数据的时候都是需要对数据进行增删改,所以会特别的慢,慢到什么程度呢,一条数据因为同时要操作多个表,以至于一条数据两分钟,后来弄了半天才发现原来是表里边没有加索引。    于是在网上查了一下索引,在这里就给大家简单的介绍一下用处和用法,至于最基本的原理,我也每太卡动,就不在这里献丑了,但是相信大家看完这篇博客能对咱们的索引有一个大概的认识。    索引,使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多列的值进行排序的一种结构。介绍**重点内容**    在关系数据库中,索引是一种与表有关的数据库结构,它可以使对应于表的SQL语句执行得更快。索引的作用相当于图书的目录,可以根据目录中的页码快速找到所需的内容。当表中有大量记录时,若要对表进行查询,第一种搜索信息方式是全表搜索,是将所有记录一一取出,和查询条件进行一一对比,然后返回满足条件的记录,这样做会消耗大量数据库系统时间,并造成大量磁盘I/O操作;第二种就是在表中建立索引,然后在索引中找到符合查询条件的索引值,最后通过保存在索引中的ROWID(相当于页码)快速找到表中对应的记录。    索引是一个单独的、物理的数据库结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。    索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序。数据库使用索引的方式与您使用书籍中的索引的方式很相似:它搜索索引以找到特定值,然后顺指针找到包含该值的行。    在数据库关系图中,可以在选定表的“索引/键”属性页中创建、编辑或删除每个索引类型。当保存索引所附加到的表,或保存该表所在的关系图时,索引将保存在数据库中。**优缺点**    在数据库系统中建立索引主要有以下作用:    (1)快速取数据;    (2)保证数据记录的唯一性;    (3)实现表与表之间的参照完整性;    (4)在使用ORDER by、group by子句进行数据检索时,利用索引可以减少排序和分组的时间。    缺点    1.索引需要占物理空间。    2.当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,降低了数据的维护速度。    在创建索引之前,您必须确定要使用哪些列以及要创建的索引类型。创建**重点内容**1.ALTER TABLEALTER TABLE用来创建普通索引、UNIQUE索引或PRIMARY KEY索引。    ALTER TABLE table_name ADD INDEX index_name (column_list)    ALTER TABLE table_name ADD UNIQUE (column_list)     ALTER TABLE table_name ADD PRIMARY KEY (column_list)    其中table_name是要增加索引的表名,column_list指出对哪些列进行索引,多列时各列之间用逗号分隔。索引名index_name可选,缺省时,MySQL将根据第一个索引列赋一个名称。另外,ALTER TABLE允许在单个语句中更改多个表,因此可以在同时创建多个索引。    2.CREATE INDEX    CREATE INDEX可对表增加普通索引或UNIQUE索引。    CREATE INDEX index_name ON table_name (column_list)    CREATE UNIQUE INDEX index_name ON table_name (column_list)    table_name、index_name和column_list具有与ALTER TABLE语句中相同的含义,索引名不可选。另外,不能用CREATE INDEX语句创建PRIMARY KEY索引。    其实大家在建表的时候,如果有主键的话,那么系统会自动为大家建立一个索引,而索引列就是主键的列,但是大家在查询的时候又不用主键的id来查询,所以大家建索引的时候一定要确保我们的查询条件就是索引的列。
0 0
原创粉丝点击