【#文档大全网# 导语】以下是®文档大全网的小编为您整理的《sqlserver全文检索》,欢迎阅读!
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')
本文来源:https://www.wddqxz.cn/726597ea4afe04a1b071de35.html