1).安裝full text search全文索引服務(wù);
2).為數(shù)據(jù)表建立full text catalog全文索引目錄;
3).進(jìn)行full text catalog的population操作(使全文索引與數(shù)據(jù)表內(nèi)容同步);
4).使用全文索引進(jìn)行查詢。
為了在數(shù)據(jù)表內(nèi)容更新時SQL Server全文索引數(shù)據(jù)庫的內(nèi)容也保持最新,可以通過第5步建立full text catalog 的Population自動操作Schedule.
1.SQL Server默認(rèn)不安裝full text search service,需要安裝時選擇裝上才可以使用。如果安裝了full text search service,那么SQL Server Enterprise manager(企業(yè)管理器)中,展開一個數(shù)據(jù)庫,會有一個Full Text Catalogs;選中一個數(shù)據(jù)庫。
右鍵菜單的“新建“中有一個New Full Text CataLog.并且選中任意一個表格,點右鍵,會有一個Full-text Index Table(全文索引表)的菜單可以使用。如果full text search service沒有安裝,那么這個菜單是灰色的。
2.為表建立full text catalog.假設(shè)數(shù)據(jù)庫CoreDB中有一個表myBBS,這個表存儲的是一個論壇所有帖子的ID,標(biāo)題(title),作者(author),內(nèi)容(content)等。我們選中表myBBS,點右鍵,New Full Text Catalog,選擇content作為SQL Server全文索引的字段,建立新的Full Text Catalog,取名為content.
3.到這個時候,只是建立了full text catalog,并不能使用全文索引。需要使全文目錄中的內(nèi)容與數(shù)據(jù)庫索引表的內(nèi)容相一致,這一步通過Full Population或Incremental Population來實現(xiàn):企業(yè)管理器中展開數(shù)據(jù)庫CoreDB,雙擊Full-Text Catalog,會看到有一個名為content的全文目錄,選中右擊,點Start Full Population或Start Incremental Population,此時即可使用索引功能。
4.使用索引功能:
select * from mybbs where Contains(content,’"windows"’); 此語句在mybbs表的SQL Server全文索引content中,查詢含有windows字符串的記錄。
5.以后數(shù)據(jù)庫中的索引表有更新時,都需要進(jìn)行Population同步操作,全文查詢的內(nèi)容才是新的數(shù)據(jù)表中的內(nèi)容。因此我們可以設(shè)定SQL Server自動進(jìn)行Population操作:右擊名為content的full text catalog,Schedules,New Catalog Schedules,輸入名字,選中Enabled選項,可以設(shè)置計劃任務(wù)的執(zhí)行頻率,可設(shè)置每次啟動SQL Server agent的時候啟動,也可以設(shè)置執(zhí)行一次,或者設(shè)置重復(fù)執(zhí)行,重復(fù)執(zhí)行里面可以設(shè)置執(zhí)行頻率為月,周,日,可以設(shè)置每天若干小時執(zhí)行一次。(這樣只要Service里面啟動了SQL Server agent,population同步計劃都會自動執(zhí)行)
總結(jié)一下,通過安裝全文索引服務(wù),建立數(shù)據(jù)表的SQL Server全文索引目錄,同步全文索引數(shù)據(jù)庫之后,即可開始使用全文索引查詢?赏ㄟ^建立full text catalog的自動population schedule來自動同步索引數(shù)據(jù)庫。
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |