关于SQLServer2000数据库索引的总结

(补)2005年8月 整理的文档资料
一、索引:根据一列或多列的值,对表中的行进行快速访问
作为索引的列:包括在where子句中;查询经常用到的列;Order By子句常用到的列

 

聚集索引——“簇索引” 每个表只能有一个聚集索引
非聚集索引——“非簇索引” sql-server默认的索引类型

 

 

动作描述 使用聚集索引 使用非聚集索引
列经常被分组排序
返回某范围内的数据 不应
一个或极少不同值 不应 不应
小数目不同值 不应
大数目不同值 不应
频繁更新的列 不应
外键列
主键列

 

 

 

查看表的索引: exec sp_helpindex TableName

 

两种方法在SQLServer中定义索引

(1)创建并命名为索引

(2)在创建Table时,使用如下约束:PK,UNIQUE,CLUSTERED,NONCLUSTERED

注意:数据类型为text,ntext,image 或 bit的列不能作为索引的列;索引列的宽度不能超过900字节

 

二、全文索引 用于在对数据量很大的表中进行查询

基本概念——(SQLServer200联机文档)

(1)全文索引为在字符串数据中进行复杂的词搜索提供有效支持

(2)全文索引存储关于重要词和这些词在特定列中的位置的信息,全文查询利用这些信息,可快速搜索包含具体某一个词

或一组词的行

(3)全文索引包含在全文目录中,每个数据库可包含一个或多个全文目录,但一个目录不能属于多个数据库

(4)每个目录可以包含一个或多个表的全文索引;一个表只能有一个全文索引

(5)全文目录和索引不存储在它们所属的数据库中

(6)全文索引必须在基表上定义,不能在视图,系统表,临时表上定义

 

 

sql语法:

当建立了全文索引,则对表的查询可以用 contains 替代 like

contains检索是区分大小写的,与like不同

如:select xx.xx from TableName where contains(字段名,'匹配值')

也可结合使用 AND|AND NOT|OR   指定两个包含搜索条件之间的逻辑运算

 

如:select xx from TableName where contains(字段名,' "sea*" or "bread*" ')

表示包含字符串 "sea"  或 "bread"  的所有 xx

 

 

 

 

使用freetext 用于搜索含有基于字符的类型的列

 

(SQLServer200联机文档)

输入单词或短语的任意集合,甚至一个完整的句子。全文查询引擎将检查该文本,标识出所有重要的单词和名词短语,并用这些条件在内部构造一个查询

 

如使用 FREETEXT 谓词查询名为 description 的一列。

 

select xx from TableName where 

FREETEXT (description, ' "The Fulton County Grand Jury said Friday an investigation of Atlanta's recent primary election produced no evidence that any irregularities took place." ')

检索引擎将标识出如下的单词和名词短语:

 

单词

Fulton, county, grand, jury, Friday, investigation, Atlanta, recent, primary, election, produce, evidence, irregularities

 

短语

Fulton county grand jury, primary election, grand jury, Atlanta's recent primary election

 

FREETEXT 字符串中的这些单词和短语(及其变形)在内部结合到一个查询中,并被赋予适当的加权等级值,然后才执行实际的检索。

 

填充形式(SQLServer200联机文档)

(1)完全填充

如为全文目录请求完全填充,则为该目录所涉及的所有表中的所有行生成索引项

如为表请求,则为该表中所有行生成索引项

 

(2)更改跟踪填充  维护在系统表中已修改的行的记录,并将更改传播到全文索引

(3)增量填充 只调整自上次填充后,添加、删除或修改的行的索引项

该功能要求索引表包含timestamp数据类型,否则只能执行前二者

对不包含timestamp的列的表请求进行增量填充仍将为表进行完全填充操作

 

 

 

 

<!---->

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(sql,搜索引擎,SQL Server,全文检索)