(补)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的列的表请求进行增量填充仍将为表进行完全填充操作