加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL索引的正确用法是什么,何时规避用索引

发布时间:2023-05-29 14:03:34 所属栏目:MsSql教程 来源:
导读:关于“SQL索引的正确用法是什么,何时避免用索引”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋
关于“SQL索引的正确用法是什么,何时避免用索引”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋友就继续往下看吧。
 
SQL 索引
 
 索引是一种特殊的查询表,可以被数据库搜索引擎用来加速数据的检索。简单说来,索引就是指向表中数据的指针。数据库的索引同书籍后面的索引非常相像。
 
 例如,如果想要查阅一本书中与某个特定主题相关的所有页面,你会先去查询索引(索引按照字母表顺序列出了所有主题),然后从索引中找到一页或者多页与该主题相关的页面。
 
 索引能够提高 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 UNIQUE INDEX index_name
 
on table_name (column_name);
 
 如果您希望索引不止一个列,您可以在括号中列出这些列的名称,用逗号隔开:
 
CREATE INDEX index_name
 
on table_name (column1, column2);
 
隐式索引:
 
 隐式索引由数据库服务器在创建某些对象的时候自动生成。例如,对于主键约束和唯一约束,数据库服务器就会自动创建索引。
 
DROP INDEX 命令:
 
 索引可以用 SQL DROP 命令删除。删除索引时应当特别小心,数据库的性能可能会因此而降低或者提高。
 
 其基本语法如下:
 
DROP INDEX table_name.index_name;
 
什么时候应当避免使用索引?
 
 尽管创建索引的目的是提升数据库的性能,但是还是有一些情况应当避免使用索引。下面几条指导原则给出了何时应当重新考虑是否使用索引:
 
小的数据表不应当使用索引;
 
需要频繁进行大批量的更新或者插入操作的表;
 
如果列中包含大数或者 NULL 值,不宜创建索引;
 
频繁操作的列不宜创建索引。
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章