创建SQL Server全文检索的2方案

此文章主要向大家讲述的是创建SQL Server全文检索的正确操作方案,如果你对创建SQL Server全文检索的正确操作步骤有兴趣了解的话,以下的文章你就可以对其进行点击观看了,以下就是文章的主要方案的描述。

方法一:先启动全文索引服务,查看当前数据库的状态SELECT DATABASEPROPERTY ('pubs','IsFulltextEnabled'),打开FullText功能sp_fulltext_databse 'enable',关闭此功能sp_fulltext_databse 'disable',在所有创建的表上建唯一索引(若已有主键索引可省),在表上点右键进入定义全文索引向导创建。

方法二:1、首先创建一个全文目录,一个全文目录可以包含多个全文索引,但一个全文索引只能用于构成一个全文目录。每个数据库可以不包含全文目录或包含多个全文目录。as default参数表明把此全文目录作为默认的全文目录。

 
 
  1. Create fulltext catalog DocumentCatalog as default 

2、然后创建唯一非聚集索引。

 

 
 
  1. create unique index T_DocumentsContent_VerID on T_DocumentsContent(VerID) 

这个一般把你要全文索引的表上的主键作为唯一非聚集索引。该索引将强制插入列中的数据具有唯一性。一般都是主键符合这个要求。

 

3、最后一步就是创建全文索引

 
 
  1. Create FULLTEXT INDEX ON T_DocumentsContent(DOCUCONTENT TYPE COLUMN ExtendedName)  
  2. key index T_DocumentsContent_VerID on DocumentCatalog  
  3. with change_tracking auto 

T_DocumentsContent:用于全文索引的表明

 

DocuContent:用于SQL Server全文检索的字段

 

如果用于SQL Server全文检索的字段是二进制流文件,那么要通过指定这个二进制流文件的扩展名由哪个列提供数据。如上例的Type Column ExtendedName,表明DocuContent的类型由ExtendedName列提供

 

key index用来指定全文索引表唯一键索引的名称

 

on DocumentCatalog:表明这个全文索引是建立在哪个全文目录上

 

with Change_Tracking:指定 SQL Server 是否维护一份对索引数据的全部更改的列表。更改跟踪不会记录通过 WRITETEXT 和 UPDATETEXT 进行的数据更改。他有几个选项

 

1. MANUAL: 指定是使用 SQL Server 代理按计划传播更改跟踪日志,还是由用户手动进行传播。

 

2.AUTO:指定在关联的表中修改了数据时,SQL Server 自动更新全文索引。默认值为 AUTO。

 

3.OFF [ ,NO POPULATION] 指定 SQL Server 不保留对索引数据的更改的列表。仅当ANGE_TRACKING 为 OFF 时,才能使用 NO POPULATION 选项。如果指定了 NO POPULATION,则 SQL Server 在创建索引后不会对其进行填充。

只有在用户使用 START FULL 或 INCREMENTAL POPULATION 子句执行 ALTER FULLTEXT INDEX 命令后,才会填充索引。如果未指定 NO POPULATION,则 SQL Server 创建索引后将对其进行完全填充

 

当然如果需要使用全文索引需要把全文索引服务启动,就是SQL Server FullText Search这个服务。注意Sql Express版本不能使用全文索引。

 

最后剩下如何进行全文检索的查询了。在查询种我们不能使用like关键字来进行SQL Server全文检索,应该使用Contains谓词,他的第一个参数是你要全文检索的列名,可以指定多个列,用都好分割,并且必须用小括号括起来,第二个参数是需要搜索的文本,第二个参数前后必须用单引号包含起来,里面查询的文本可用引号包含,并且可以使用通配符和条件语句,如

where Contains(a.Content, '"中国*" or "武汉"')

条件语句可以用符号来代理如AND可以用&来代替,具体参看SQLServer的帮助文档。

 

第三个参数是查询的语言。如果一个列里面存储了多种语言,允许用户指定搜索的语言。

除了Contains谓词可以用于全文检索FreeText也可以进行SQL Server全文检索,但次谓词用于搜索含有基于字符的数据类型的列,好像不能搜索二进制流的列,但帮助文档却又说支持Image的列。但是FreeText的搜索精度没有Contains的谓词高,推荐使用Contains谓词。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值