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

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

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

C#中lock关键字的使用小结

《C#中lock关键字的使用小结》在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块,下面就来介绍一下lock关键字的使用... 目录使用方式工作原理注意事项示例代码为什么不能lock值类型在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时