使用sql server中的全文索引

來源:互聯網
上載者:User
 一般情況,使用sql server中的全文索引,經過大體4個步驟:

     1).安裝full text search全文索引服務;

     2).為資料表建立full text catalog全文索引目錄;

     3).進行full text catalog的population操作(使全文索引與資料表內容同步);

     4).使用全文索引進行查詢。

     為了在資料表內容更新時全文索引資料庫的內容也保持最新,可以通過第5步建立full text catalog 的Population自動操作Schedule.

     1.sql server預設不安裝full text search service,需要安裝時選擇裝上才可以使用。如果安裝了full text search service,那麼Sql Server Enterprise manager(企業管理器)中,展開一個資料庫,會有一個Full Text Catalogs;選中一個資料庫,右鍵菜單的“建立“中有一個New Full Text CataLog.並且選中任意一個表格,點右鍵,會有一個Full-text Index Table(全文索引表)的菜單可以使用。如果full text search service沒有安裝,那麼這個菜單是灰色的。

     2.為表建立full text catalog.假設資料庫CoreDB中有一個表myBBS,這個表格儲存體的是一個論壇所有文章的ID,標題(title),作者(author),內容(content)等。我們選中表myBBS,點右鍵,New Full Text Catalog,選擇content作為全文索引的欄位,建立新的Full Text Catalog,取名為content.

     3.到這個時候,只是建立了full text catalog,並不能使用全文索引。需要使全文檢索目錄中的內容與資料庫索引表的內容相一致,這一步通過Full Population或Incremental Population來實現:企業管理器中展開資料庫CoreDB,雙擊Full-Text Catalog,會看到有一個名為content的全文檢索目錄,選中右擊,點Start Full Population或Start Incremental Population,此時即可使用索引功能。

     4.使用索引功能:

     select * from mybbs where Contains(content,'"windows"');

     此語句在mybbs表的全文索引content中,查詢含有windows字串的記錄。

     5.以後資料庫中的索引表有更新時,都需要進行Population同步操作,全文檢索查詢的內容才是新的資料表中的內容。因此我們可以設定sql server自動進行Population操作:右擊名為content的full text catalog,Schedules,New Catalog Schedules,輸入名字,選中Enabled選項,可以設定計劃任務的執行頻率,可設定每次啟動SQL server agent的時候啟動,也可以設定執行一次,或者設定重複執行,重複執行裡面可以設定執行頻率為月,周,日,可以設定每天若干小時執行一次。(這樣只要Service裡面啟動了sql server agent,population同步計劃都會自動執行)

     總結一下,通過安裝全文索引服務,建立資料表的全文索引目錄,同步全文索引資料庫之後,即可開始使用全文索引查詢。可通過建立full text catalog的自動population schedule來自動同步索引資料庫。
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.