位置:首页 > 数据库 > SQLite在线教程 > SQLite 索引

SQLite 索引

索引是一种特殊的查找表,可以使用搜索引擎的数据库,以加快数据检索。简单地说,索引是一个指针,表中的数据。一个数据库中的索引是非常相似在一本书的背部的索引。

例如,如果你想在一本书中引用的所有页面讨论某个话题,先参考索引,按字母顺序列出所有主题,再交由一个或多个特定的页码。

索引有助于加快SELECT查询和WHERE子句,但它会减慢数据的输入,UPDATE和INSERT语句。索引可以创建或删除,但数据不会影响。

创建索引涉及CREATE INDEX语句,它允许命名的索引,索引指定表的一列或多列,并指示索引是否在升序或降序排列。

索引也可以是唯一的,类似UNIQUE约束,在列上有一个索引的列或组合索引防止重复条目。

CREATE INDEX命令:

CREATE INDEX的基本语法如下:

CREATE INDEX index_name ON table_name;

单列索引:

单列索引是一个只有基于一个表的列上创建。基本语法如下:

CREATE INDEX index_name
ON table_name (column_name);

唯一索引:

使用唯一索引不仅是性能,同时也为数据的完整性。唯一索引不允许任何重复的值插入到表中。基本语法如下:

CREATE INDEX index_name
on table_name (column_name);

复合索引:

组合索引是一个表的两个或多个列上的索引。基本语法如下:

CREATE INDEX index_name
on table_name (column1, column2);

是否要创建一个单列索引或组合索引,考虑到列,可以使用非常频繁查询的WHERE子句作为过滤条件。

应该有一列,单列索引应该是选择。如果有两个或多个列中经常使用的WHERE子句作为过滤器,组合索引将是最好的选择。

隐式索引:

隐式式索引是由数据库服务器创建一个对象时,会自动创建索引。索引自动创建的主键约束和唯一约束。

例子

下面是一个例子,我们将创建一个索引表COMPANY的 薪水列:

sqlite> CREATE INDEX salary_index ON COMPANY (salary);

现在,让我们列出了所有的索引,COMPANY表使用.indices命令​​如下:

sqlite> .indices COMPANY

这将产生以下结果,其中sqlite_autoindex_COMPANY_1是创建表本身时创建了一个隐式索引。

salary_index
sqlite_autoindex_COMPANY_1

可以列出所有的索引数据库范围如下:

sqlite> SELECT * FROM sqlite_master WHERE type = 'index';

DROP INDEX命令:

一个索引可以使用SQLite DROP命令删除。应注意当删除索引,因为性能可能会减缓或改善。

基本语法如下:

DROP INDEX index_name;

可以使用下面的语句来删除以前创建的索引:

sqlite> DROP INDEX salary_index;

索引什么情况避免使用?

虽然索引的目的在于提高数据库的性能,有时间时,应避免。使用索引时,应重新考虑下列准则:

  • 索引不应该使用较小的表上。

  • 有频繁的,大批量的更新或插入操作的表。

  • 索引不应使用含有大量的NULL值的列。

  • 频繁操作的列都将不会被索引。