全文索引的使用方法(一)

2024-02-27 20:18
文章标签 使用 方法 全文索引

本文主要是介绍全文索引的使用方法(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://blog.csdn.net/HEROWANG/archive/2009/08/11/4436605.aspx


view plaincopy to clipboardprint?
01./*建立测试环境*/ 
02. 
03.if object_id('tb') is not null 
04. 
05.   drop table tb 
06. 
07.go 
08. 
09.create table tb 
10. 
11.(id int identity(1,1), 
12. 
13. title varchar(200),  
14. 
15. detail varchar(1000), 
16. 
17. constraint pk_id primary key(id) –在建立全文索引时需要使用 
18. 
19. ) 
20. 
21.insert into tb 
22. 
23.select '火箭即将签下新秀射手',' 据悉,巴丁格与火箭队的合同谈判是于昨天完成的,巴丁格将得到与泰勒一样的合同。此前媒体曝光泰勒的合同为期四年,总价值万美元,其中前两年为保障性合同。巴丁格预计会在接下来几天内正式宣布签约加盟火箭。'  
24. 
25.union all 
26. 
27.select '韦弗被曝已与希腊豪门签约','据国际篮球网报道,前火箭队球员范-韦弗已经与希腊豪门奥林匹亚科斯队签订了合同。韦弗得到一份为期两年,总价值万美元的合同。' 
28. 
29.union all 
30. 
31.select '马刺豪掷千金为对抗湖人','马刺队在今夏休赛期补充了几员大将,主教练格雷格-波波维奇日前在接受Yahoo!体育采访时透露,马刺队不惜缴纳奢侈税构建豪华阵容就是为了对抗湖人队,争取拿到第五个总冠军。' 
32. 
33.union all 
34. 
35.select '华莱士未曾想过离开汽车城','此前本-华莱士已经同意重返底特律活塞,并且以老将底薪和活塞签下一份年万美元的合同,而据《每日先驱报》专栏作家米克-麦格劳透露,这位当年叱咤NBA赛场的内线防守悍将甚至从来就没有考虑过要离开活塞队。' 
36. 
37.union all 
38. 
39.select '米勒竟好横刀夺爱追求人妻','对于那些没看过雷吉·米勒在步行者创造“米勒时间”的“后”们,应该怎么介绍这位前NBA球星呢?难道从前天洛杉矶马里布海滩上空那架飞机拉的横幅说起?恐怕没有哪位家长愿意这么做。' 
40. 
41.union all 
42. 
43.select '姚明:没把上海当投资项目乐得生意做了好人当了','“姚蜜”说:不缺广告效应的姚明收购濒临绝境的上海东方篮球俱乐部,说明他是真的想为曾经的母队做点事情。' 
44. 
45.union all 
46. 
47.select '火箭不敌奇才终结年纪录','此役姚麦组合状态糟糕,姚明投中得到分个篮板次盖帽,麦迪投中拿下分个篮板次助攻,两人联手竟不如得到分个篮板次助攻次盖帽的贾米森。' 
48. 
49.  
50. 
51.第一步:启用数据库的全文索引 
52. 
53.sp_fulltext_database enable   --启用数据库的全文索引 
54. 
55.go 
56. 
57.第二步:建立全文目录 
58. 
59.create fulltext catalog tb_fulltext   
60. 
61.in path N'D:/Program Files/Microsoft SQL Server2005/MSSQL.1/MSSQL/FTData' 
62. 
63.with accent_sensitivity =on  --区分重音 
64. 
65.authorization dbo;--全文目录的所有者 
66. 
67.第三步:建立全文索引 
68. 
69.create fulltext index on tb 
70. 
71.(title,detail) 
72. 
73.key index pk_id  --指定索引列,为了提高性能,最好使用聚集索引 
74. 
75.on tb_fulltext 
76. 
77.with change_tracking auto  --在关联的表中修改了数据时,自动更新全文索引。 
78. 
79.  
80. 
81.第四步:查询示例: 
82. 
83.select * from tb 
84. 
85.where contains((title,detail),'姚明') 
 
 


查询的语法:
 
1、  搜索特定词:contains(detail,'姚明')
 
2、  搜索特定短语:用““将短语包含在双引号内,contains(detail,'姚明 上海')
 
3、  从多个列中搜索词和短语:contains((title,detail),'姚明 上海')
 
4、搜索以指定文本开头的词或短语:contains(detail,'“姚明*“')
 
如果文本和星号不包含在双引号内,则全文搜索会将星号看做是一个字符。如果搜索的是短语,则该短语内的每个词都被看做是一个前缀。contains(detail,'“姚明 上海*“')则将返回第一个词以姚明开头第二个词以上海开头的结果
 
5、  搜索特定词的变形:contains(detail,'formsof(inflectional,ride)')
 
将返回表中含有ride,rides,riding,ridden的行
 
6、搜索与另一个词或短语临近的词或者短语:contains(detail,'姚明 near 上海')
 
7、使用加权值的词或短语:contains(description,’isabout(performance weight(.8),comfortable weight(.4),smooth weight(.2))’)
 
Weight为每个词或短语指定一个0.0~1.0之间的加权值
 
8、使用多个搜索条件: contains(detail,'”姚明” or “上海”')
 
                     contains(detail,'”姚明” and “上海”')
 
                       contains(detail,'”姚明” and not  “上海”')
 
9、在contains中还可以使用变量
 
10、搜索同义词         contains(title,'formsof(thesaurus,上)')


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/HEROWANG/archive/2009/08/11/4436605.aspx

这篇关于全文索引的使用方法(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/753494

相关文章

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建