sqlserver全文检索
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Sqlserver 全文检索功能浅解
全文索引和全文检索是sql server 7.0的新增功能,它能够对数据中的字符类型列(如varchar、text等类型列)进行检索,并通过索引实现全文搜索查询。sql server常规索引与全文检索相比,二者的区别如下:
常规索引全文索引
使用create index或约束定义创建
通过删除或执行drop index语句删除
使用全文索引存储过程创建和删除
当插入、修改或删除数据时,sql server能够自动更新常规索引内容只能通过任务调度或执行存储过程来填充全文索引
每个表可以建立多个常规索引,索引不能分组每个表只能有一个全文索引,同一个数据库中的多个全文索引可以组织为一个全文目录
常规索引存储在数据库文件中全文索引存储在文件系统中
为了支持全文索引操作,sql server 7.0新增了一些新存储过程和transact-sql语句,使用这些存储过程创建全文索引的SQL SERVER数据库全文索引的示例,以test数据库为例。
首先,介绍利用系统存储过程创建全文索引的具体步骤:
1) 启动数据库的全文处理功能(sp_fulltext_database)
2) 建立全文目录(sp_fulltext_catalog)
3) 在全文目录中注册需要全文索引的表(sp_fulltext_table)
4) 指出表中需要全文索引的列名(sp_fulltext_column)
5) 为表创建全文索引(sp_fulltext_table)
6) 填充全文目录(sp_fulltext_catalog)
---------********示例********-------------
说明:下面所用到的test为数据库名,dbo.T_FX_DRM_20为test数据库中的一张表,FX_D20_ID是表dbo.T_FX_DRM_20中的一个列名
以对test数据库的表dbo.T_FX_DRM_20的FX_D20_ID列建立全文索引,之后使用索引查询FX_D20_ID列中包含有"*****"字符串的数据:在这之前,需要安装Microsoft Search 服务,启动SQL server全文搜索服务。
use test
go
exec sp_fulltext_database 'enable'
为dbo.T_FX_DRM_20表建立全文索引数据元,其中create为建立,activate为激活,deactivate为关闭表全文索引的激活状态,使它不再参加全文目录填充,drop为删除;create 参数中,后面跟的是全文目录名称和索引列名。
下面语句为test数据库中的dbo.T_FX_DRM_20表创建全文索引数据元,存储该数据元的全文目录为FT_pubm,所使用的唯一索引为PK_T_FX_DRM_20(dbo.T_FX_DRM_20表中为FX_D20_ID列的PRIMARY KEY约束所建立的唯一索引)
sp_fulltext_table titles,'create','FT_pubs','PK_T_FX_DRM_20'
--激活它
sp_fulltext_table dbo.T_FX_DRM_20,'activate'
--指定参加全文索引的列
sp_fulltext_column 'dbo.T_FX_DRM_20','FX_D20_ID','add'
下面是一个完整的例子:
在执行该脚本程序之前启动sql server的全文搜索服务,即microsoft search 服务
use test--打开数据库
go
检查test是否支持全文索引,如果不支持全文索引,则使用sp_fulltext_datebase打开该功能
if (select databaseproperty ('test','IsFulltextEnables'))=0
exec sp_fulltext_database 'enable' --启动数据库的全文处理功能
----建立全文目录
exec sp_fulltext_catalog 'FT_pubm','create'
----在全文目录中注册需要全文索引的表
exec sp_fulltext_table 'dbo.T_FX_DRM_20','create','FT_pubm','PK_T_FX_DRM_20' ----指出表中需要全文检索的列名
exec sp_fulltext_column 'dbo.T_FX_DRM_20','FX_D20_ID','add'
----激活全文检索的能力,也就是在全文目录中注册该表
exec sp_fulltext_table 'dbo.T_FX_DRM_20','activate'
----填充全文目录
exec sp_fulltext_catalog 'FT_pubm','start_full'
--检查全文目录填充情况
While fulltextcatalogproperty('FT_pubm','populateStatus')<>0
begin
--如果全文目录正处于填充状态,则等待30秒后再检测一次
waitfor delay '0:0:30'
end
//应用全文检索找出列FX_D20_ID中包含“aaaaaaaaa”的所有数据
select * from dbo.T_FX_DRM_20 where contains(FX_D20_ID,'aaaaaaaaa')
以下介绍一下全文操作类的系统存储过程:
过程名称:sp_fulltext_service
执行权限:serveradmin或系统管理员
作用:设置全文搜索属性
过程名称:sp_fulltext_catalog
执行权限:db_owner及更高角色成员
作用:创建和删除一个全文目录,启动或停止一个全文目录的索引操作过程名称:sp_fulltext_database
执行权限:db_owner角色成员
作用:初始化全文索引或删除数据库中所有全文目录
过程名称:sp_fulltext_table
执行权限:db_adnmin或db_owner角色成员
作用:将一个表标识为全文索引表或非全文索引表
过程名称:sp_fulltext_column
执行权限:db_adnmin角色成员
作用:指出一个全文索引表中的那些列假如或退出全文索引