SQL?Server的全文搜索功能
一、使用SQL Server全文搜索配置
要使用SQL Server的全文搜索服務(wù),需要進(jìn)行如下配置。
1、開啟全文搜索服務(wù):
2、開啟數(shù)據(jù)庫(kù)的全文索引功能:
--開啟數(shù)據(jù)庫(kù)的全文搜索功能 EXEC sp_fulltext_database 'enable';
3、創(chuàng)建全文索引目錄:
--創(chuàng)建全文索引目錄 CREATE FULLTEXT CATALOG IndexCatalog ON FILEGROUP [PRIMARY] IN PATH 'E:\SQLServerIndex' AS DEFAULT
4、創(chuàng)建唯一索引:
--創(chuàng)建唯一索引 CREATE UNIQUE NONCLUSTERED INDEX IndexContent ON Article(ArticleContent ASC)
5、創(chuàng)建全文索引:
--創(chuàng)建全文索引 CREATE FULLTEXT INDEX ON Article (ArticleContent) KEY INDEX IndexContent ON IndexCatalog --IndexContent是唯一索引名
二、使用全文搜索
CONTAINS搜索方式
1.簡(jiǎn)單詞搜索
- 搜索一個(gè)或多個(gè)特定的詞或短語(yǔ)。詞可以包括一個(gè)或多個(gè)字符,中間沒有空格或標(biāo)點(diǎn)。短語(yǔ)可以由空格分隔的多個(gè)詞組成,但詞之間可以有標(biāo)點(diǎn)也可以沒標(biāo)點(diǎn):
--搜索文章內(nèi)容含有張三或者李四的記錄 SELECT * FROM Article WHERE CONTAINS(ArticleContent,'"張三" OR "李四"')
2.前綴詞搜索的方式
- 搜索指定文本開頭的詞或短語(yǔ),前綴詞的搜索方式主要是用在搜索英文中,例如搜索以“do”開頭的單詞,則可以將doctor、document、download等單詞都搜索出來。
--搜索文章內(nèi)容中含有以'認(rèn)'開始的詞的記錄 SELECT * FROM Article WHERE CONTAINS(ArticleContent,'"認(rèn)*"') --認(rèn)為,認(rèn)識(shí)
3.加權(quán)詞搜索的方式
- 給多個(gè)搜索條件加上權(quán)值,加權(quán)值越高的記錄排在越前面,當(dāng)以多個(gè)字符串作為搜索條件搜索記錄時(shí),可以為不同的字符串加上一個(gè)加權(quán)值,這個(gè)加權(quán)值是介于0和1之間的數(shù)值,加權(quán)值越高的記錄排在越前面。事實(shí)上在該SELECT語(yǔ)句的返回結(jié)果集里,并沒有按加權(quán)值的大小來排序,因?yàn)閃EIGHT不影響CONTAINS查詢的結(jié)果,只會(huì)影響CONTAINSTABLE查詢中的排序:
--在CONTAINS搜索中,權(quán)重并不影響排序 SELECT * FROM Article WHERE CONTAINS(ArticleContent,'ISABOUT ("北京" weight(0.9),"上海" weight(0.6),"廣州" weight(0.5))')
4.鄰近詞搜索的方式
- 可以搜索與另一個(gè)詞或短語(yǔ)相鄰近的詞或短語(yǔ):
--搜索文章內(nèi)容中第二個(gè)詞在第一個(gè)詞附近的記錄 SELECT * FROM Article WHERE CONTAINS(ArticleContent,'"張三" NEAR "李四"')
FREETEXT搜索方式
FREETEXT搜索方式與CONTAINS搜索方式相比,其搜索結(jié)果表現(xiàn)都十分不精確,因?yàn)镕REETEXT的搜索方式是將一個(gè)句子中的每個(gè)單字拆分開進(jìn)行搜索的。使用CONTAINS搜索方式搜索條件為“教育部”的記錄,那么搜索出來的將是記錄里包含“教育部”三個(gè)字符串的記錄。
--搜索文章內(nèi)容中包含'程'字和'社'字的記錄 SELECT * FROM Article WHERE FREETEXT(ArticleContent,'程社')
CONTAINSTABLE搜索方式
1、CONTAINSTABLE基本搜索:
--CONTAINSTABLE搜索文章內(nèi)容中含有友誼的記錄 SELECT * FROM CONTAINSTABLE(Article,ArticleContent,'友誼') as table1
留意到返回中指包含了兩個(gè)字段:
其實(shí)就是CONTAINSTABLE表中的數(shù)據(jù)。
2、CONTAINSTABLE返回所需列:
--CONTAINSTABLE搜索返回所需列 SELECT * FROM Article JOIN CONTAINSTABLE(Article,ArticleContent,'"環(huán)境"',2) as table1 ON Article.ArticleContent = table1.[KEY] ORDER BY table1.RANK DESC
3、CONSTAINSTABLE按符合條件排序
--按符合條件排序 SELECT * FROM Article JOIN CONTAINSTABLE(Article,ArticleContent,' "泰國(guó)" NEAR "高鐵" ',10) as table1 ON Article.ArticleContent = table1.[KEY] ORDER BY table1.RANK DESC
看到查詢結(jié)果的確按符合條件進(jìn)行了排序:
4、CONSTAINSTABLE按按權(quán)值排序
--權(quán)重值排序 SELECT * FROM Article JOIN CONTAINSTABLE(Article,ArticleContent, 'ISABOUT ("泰國(guó)" weight(0.9), "高鐵" weight(0.6), "環(huán)境" weight(0.1))') AS TABLE1 ON Article.ArticleContent = TABLE1.[KEY] ORDER BY TABLE1.RANK DESC
結(jié)果按照權(quán)重值排序:
使用FREETEXTTABLE搜索
單個(gè)字搜索,但是多了參數(shù)可供使用:語(yǔ)法如下:
FREETEXTTABLE (table , { column_name | (column_list) | * } , 'freetext_string' [ ,LANGUAGE language_term ] [ ,top_n_by_rank ] )
示例:
搜索image字段
在SQL Server 2005的image類型的字段里,不僅僅是可以存儲(chǔ)圖形文件,還可以存儲(chǔ)如可執(zhí)行文件、音樂文件、文本文件等眾多文件類型。SQL Server 2005支持對(duì)存儲(chǔ)在image類型的字段里的一些文件的內(nèi)容進(jìn)行全文搜索,但在創(chuàng)建全文索引時(shí)必須指明存儲(chǔ)在image字段里的文件的類型。
SQL Server 2005支持對(duì)存儲(chǔ)在image中的純文本文件、網(wǎng)頁(yè)文件、Word文件、Excel文件和PowerPoint文件的內(nèi)容進(jìn)行查詢,其擴(kuò)展名字段必須分別為txt、htm、doc、xls和ppt。全文索引創(chuàng)建完畢后,對(duì)image字段里的文件內(nèi)容進(jìn)行查詢的方法與其他字段的查詢方法是一樣的:
SELECT 編號(hào),標(biāo)題,文件,擴(kuò)展名 FROM 文章 WHERE CONTAINS(文件,'數(shù)據(jù)庫(kù)')
三、小結(jié)與評(píng)價(jià)
下面給出這個(gè)SQL Server全文搜索的常用SQL語(yǔ)句:
--開啟數(shù)據(jù)庫(kù)的全文搜索功能: EXEC sp_fulltext_database 'enable'; --數(shù)據(jù)庫(kù)啟用全文索引 --關(guān)閉數(shù)據(jù)庫(kù)的全文搜索功能: EXEC sp_fulltext_database 'disable'; --數(shù)據(jù)庫(kù)禁用全文索引 --如果你忘記了全文索引的目錄、表、列創(chuàng)建過全文索引 EXEC sp_help_fulltext_catalogs --全文索引目錄 EXEC sp_help_fulltext_columns --全文索引列 EXEC sp_help_fulltext_tables --全文索引表
到此這篇關(guān)于SQL Server全文搜索的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
查詢Sqlserver數(shù)據(jù)庫(kù)死鎖的一個(gè)存儲(chǔ)過程分享
利用sp_who_lock這個(gè)存儲(chǔ)過程,可以很方便的知道哪個(gè)進(jìn)程出現(xiàn)了死鎖,出現(xiàn)死鎖的問題在哪里2014-07-07sqlserver exists,not exists的用法
exists,not exists的使用方法示例,需要的朋友可以參考下。2009-12-12SQL Server 2005/2008 用戶數(shù)據(jù)庫(kù)文件默認(rèn)路徑和默認(rèn)備份路徑修改方法
本環(huán)境是SQL Server 2005 Standard Version 64-bit 和 SQL Server 2008 Standard Version 64-bit 雙實(shí)例同時(shí)安裝在一個(gè)2010-04-04
Windows Server 2008 Standard Version 64-bit OS上限制MSSQL使用內(nèi)存的方法(針對(duì)內(nèi)存小的云主機(jī))
使用騰訊云Windows云服務(wù)器安裝SQL SERVER數(shù)據(jù)庫(kù),在我們使用的過程中,有時(shí)候在任務(wù)管理器發(fā)現(xiàn)SQL SERVE的進(jìn)程占用很高的內(nèi)存和CPU,本文介紹如何限制SQL SERVER內(nèi)存占用2023-08-08SQL SERVER函數(shù)之深入表值函數(shù)的處理分析
本篇文章是對(duì)表值函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06SqlServer 序號(hào)列的實(shí)現(xiàn)方法
對(duì)于 SQL SERVER 2000 及更早的版本,需要使用一個(gè)自增列,結(jié)合臨時(shí)表來實(shí)現(xiàn)。2009-06-06SQLServer中數(shù)據(jù)庫(kù)文件的存放方式,文件和文件組
上次我關(guān)于索引的文章有幾個(gè)園友發(fā)站內(nèi)信問我如何將索引和表存儲(chǔ)在不同的硬盤上。我覺的需要專門寫一篇文章來講述一下文件和文件組應(yīng)該更容易理解2011-12-12