SQL Server的全文搜索功能
作者:springsnow 发布时间:2024-01-27 20:49:24
一、使用SQL Server全文搜索配置
要使用SQL Server的全文搜索服务,需要进行如下配置。
1、开启全文搜索服务:
2、开启数据库的全文索引功能:
--开启数据库的全文搜索功能
EXEC sp_fulltext_database 'enable';
3、创建全文索引目录:
--创建全文索引目录
CREATE FULLTEXT CATALOG IndexCatalog
ON FILEGROUP [PRIMARY]
IN PATH 'E:\SQLServerIndex'
AS DEFAULT
4、创建唯一索引:
--创建唯一索引
CREATE UNIQUE NONCLUSTERED INDEX IndexContent ON Article(ArticleContent ASC)
5、创建全文索引:
--创建全文索引
CREATE FULLTEXT INDEX ON Article
(ArticleContent)
KEY INDEX IndexContent ON IndexCatalog --IndexContent是唯一索引名
二、使用全文搜索
CONTAINS搜索方式
1.简单词搜索
- 搜索一个或多个特定的词或短语。词可以包括一个或多个字符,中间没有空格或标点。短语可以由空格分隔的多个词组成,但词之间可以有标点也可以没标点:
--搜索文章内容含有张三或者李四的记录
SELECT * FROM Article WHERE CONTAINS(ArticleContent,'"张三" OR "李四"')
2.前缀词搜索的方式
- 搜索指定文本开头的词或短语,前缀词的搜索方式主要是用在搜索英文中,例如搜索以“do”开头的单词,则可以将doctor、document、download等单词都搜索出来。
--搜索文章内容中含有以'认'开始的词的记录
SELECT * FROM Article WHERE CONTAINS(ArticleContent,'"认*"') --认为,认识
3.加权词搜索的方式
- 给多个搜索条件加上权值,加权值越高的记录排在越前面,当以多个字符串作为搜索条件搜索记录时,可以为不同的字符串加上一个加权值,这个加权值是介于0和1之间的数值,加权值越高的记录排在越前面。事实上在该SELECT语句的返回结果集里,并没有按加权值的大小来排序,因为WEIGHT不影响CONTAINS查询的结果,只会影响CONTAINSTABLE查询中的排序:
--在CONTAINS搜索中,权重并不影响排序
SELECT * FROM Article
WHERE CONTAINS(ArticleContent,'ISABOUT ("北京" weight(0.9),"上海" weight(0.6),"广州" weight(0.5))')
4.邻近词搜索的方式
- 可以搜索与另一个词或短语相邻近的词或短语:
--搜索文章内容中第二个词在第一个词附近的记录
SELECT * FROM Article WHERE CONTAINS(ArticleContent,'"张三" NEAR "李四"')
FREETEXT搜索方式
FREETEXT搜索方式与CONTAINS搜索方式相比,其搜索结果表现都十分不精确,因为FREETEXT的搜索方式是将一个句子中的每个单字拆分开进行搜索的。使用CONTAINS搜索方式搜索条件为“教育部”的记录,那么搜索出来的将是记录里包含“教育部”三个字符串的记录。
--搜索文章内容中包含'程'字和'社'字的记录
SELECT * FROM Article WHERE FREETEXT(ArticleContent,'程社')
CONTAINSTABLE搜索方式
1、CONTAINSTABLE基本搜索:
--CONTAINSTABLE搜索文章内容中含有友谊的记录
SELECT * FROM CONTAINSTABLE(Article,ArticleContent,'友谊') as table1
留意到返回中指包含了两个字段:
其实就是CONTAINSTABLE表中的数据。
2、CONTAINSTABLE返回所需列:
--CONTAINSTABLE搜索返回所需列
SELECT * FROM Article JOIN
CONTAINSTABLE(Article,ArticleContent,'"环境"',2) as table1
ON Article.ArticleContent = table1.[KEY]
ORDER BY table1.RANK DESC
3、CONSTAINSTABLE按符合条件排序
--按符合条件排序
SELECT * FROM Article JOIN
CONTAINSTABLE(Article,ArticleContent,' "泰国" NEAR "高铁" ',10) as table1
ON Article.ArticleContent = table1.[KEY]
ORDER BY table1.RANK DESC
看到查询结果的确按符合条件进行了排序:
4、CONSTAINSTABLE按按权值排序
--权重值排序
SELECT * FROM Article JOIN
CONTAINSTABLE(Article,ArticleContent,
'ISABOUT ("泰国" weight(0.9),
"高铁" weight(0.6),
"环境" weight(0.1))') AS TABLE1
ON Article.ArticleContent = TABLE1.[KEY]
ORDER BY TABLE1.RANK DESC
结果按照权重值排序:
使用FREETEXTTABLE搜索
单个字搜索,但是多了参数可供使用:语法如下:
FREETEXTTABLE (table , { column_name | (column_list) | * }
, 'freetext_string'
[ ,LANGUAGE language_term ]
[ ,top_n_by_rank ] )
示例:
搜索image字段
在SQL Server 2005的image类型的字段里,不仅仅是可以存储图形文件,还可以存储如可执行文件、音乐文件、文本文件等众多文件类型。SQL Server 2005支持对存储在image类型的字段里的一些文件的内容进行全文搜索,但在创建全文索引时必须指明存储在image字段里的文件的类型。
SQL Server 2005支持对存储在image中的纯文本文件、网页文件、Word文件、Excel文件和PowerPoint文件的内容进行查询,其扩展名字段必须分别为txt、htm、doc、xls和ppt。全文索引创建完毕后,对image字段里的文件内容进行查询的方法与其他字段的查询方法是一样的:
SELECT 编号,标题,文件,扩展名 FROM 文章 WHERE CONTAINS(文件,'数据库')
三、小结与评价
下面给出这个SQL Server全文搜索的常用SQL语句:
--开启数据库的全文搜索功能:
EXEC sp_fulltext_database 'enable'; --数据库启用全文索引
--关闭数据库的全文搜索功能:
EXEC sp_fulltext_database 'disable'; --数据库禁用全文索引
--如果你忘记了全文索引的目录、表、列创建过全文索引
EXEC sp_help_fulltext_catalogs --全文索引目录
EXEC sp_help_fulltext_columns --全文索引列
EXEC sp_help_fulltext_tables --全文索引表
来源:https://www.cnblogs.com/springsnow/p/9881026.html
猜你喜欢
- PDO::execPDO::exec — 执行一条 SQL 语句,并返回受影响的行数(PHP 5 >= 5.1.0, PECL pdo
- 由于连续的字符(字母、符号、数字)在默认情况下是不换行的,可能会破坏整个界面布局。那如何解决这个问题呢?在 IE 和 Safari 1.3+
- 安装刚接触Pillow的朋友先来看一下Pillow的安装方法,在这里我们以Mac OS环境为例:(1)、使用 pip 安装 Python 库
- 一、管理数据库连接1、使用配置文件管理连接之约定在数据库上下文类中,如果我们只继承了无参数的DbContext,并且在配置文件中创建了和数据
- 查询所有数据库的总大小方法如下:mysql> use information_schema;mysql> select conc
- 学习目标根据原型设计编译自动化数据生成器,熟悉wxPython的基本用法。界面原型设计界面原型设计分析输入参数:最大长度最小长度组成规则多少
- 今天要处理通知书上的日期,写的一个处理程序,效率可能不是最优的,不过实现功能绝对没问题。注:月份和天要分>10,=10,<10三
- 一、re.compile 函数作用:compile 函数用于编译正则表达式,生成一个正则表达式( Pattern )对象,供 match()
- 认知心理学家Donald A. Norman将人类的行动分解成七个阶段:1. 确定目标2. 确定意图3. 明确行动内容4. 执行5. 感知外
- 机器A: select instance_name from v$instance; select name from v$database
- 基础知识优先使用异常捕获LBYL(look before you leap): 在执行一个可能出错的操作时,先做一些关键的条件判断,仅当满足
- 我就废话不多说了,大家还是直接看代码吧~import kerasfrom sklearn.model_selection import tr
- mysql 查看表空间主要是查看创建的库和系统自带的库大小 - SELECT table_schema,
- Jupyter Notebook是一个基于浏览器的交互式编程环境(REPL, read eval print loop),它主要构建在IPy
- Python语言简洁明了,可以用较少的代码实现同样的功能。这其中Python的四个内置数据类型功不可没,他们即是list, tuple, d
- 本文研究的主要是Django中Forms的使用,具体如下。创建文件do.html{% extends 'base.html'
- 本文实例讲述了python中引用与复制用法。分享给大家供大家参考。具体分析如下:在python中,任何不可变对象是传值的,而可变对象是传引用
- 如果文件已连接(与终端设备相关联)到一个tty(状)的设备,isatty()方法返回True,否则返回False。语法以下是is
- 前言上一篇文章写了关于字典操作方法的增删改,这篇主要讲解如何查找字典数据。查找数据写法一共有两种,一种能够是key值查找,另外一种是按照函数
- virtualenv介绍virtualenv为应用提供了隔离的Python运行环境,解决了不同应用间多版本的冲突问题。virtualenv把