sqlserver全文检索

2023-03-29 22:08:25   第一文档网     [ 字体: ] [ 阅读: ] [ 文档下载 ]
说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。下载word有问题请添加QQ:admin处理,感谢您的支持与谅解。点击这里给我发消息

#第一文档网# 导语】以下是®第一文档网的小编为您整理的《sqlserver全文检索》,欢迎阅读!
全文检索,sqlserver

Sqlserver 全文检索功能浅解

全文索引和全文检索是sql server 7.0的新增功能,它能够对数据中的字符类型列(如varchartext等类型列)进行检索,并通过索引实现全文搜索查询。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_20test数据库中的一张表,FX_D20_ID是表dbo.T_FX_DRM_20中的一个列名

以对test数据库的表dbo.T_FX_DRM_20FX_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_20dbo.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.dywdw.cn/726597ea4afe04a1b071de35.html

相关推荐
推荐阅读