SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けに、EnterpriseZine Day、Security Online Day、DataTechという、3つのイベントを開催しております。それぞれ編集部独自の切り口で、業界トレンドや最新事例を網羅。最新の動向を知ることができる場として、好評を得ています。

直近開催のイベントはこちら!

EnterpriseZine編集部ではイベントを随時開催しております

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けの講座「EnterpriseZine Academy」や、すべてのITパーソンに向けた「新エバンジェリスト養成講座」などの講座を企画しています。EnterpriseZine編集部ならではの切り口・企画・講師セレクトで、明日を担うIT人材の育成をミッションに展開しております。

お申し込み受付中!

あたらしいSQL Server/Denaliの世界

SQL Server 2012 フルテキスト検索の新機能(前編)

2.NEAR オプションの拡張

 SQL Server 2008 R2 までのバージョンにも、インデックス内の二つの単語が近く存在する場合ことを抽出条件とするNEAR オプションは用意されていました。たとえば、次のようなクエリを実行すると、検索対象の中で「test」と「Space」が近接しているデータを抽出します。

 これは、必ずしも連続していない二つの単語を検索条件にするときに、とても便利なオプションです。

SELECT * FROM table1 WHERE CONTAINS(*, 'test NEAR Space')

 SQL Server 2012 ではさらに NEAR オプションの使い勝手がよくなっています。それでは、便利になった部分を順番に見ていきましょう。

 まずは、二つの単語の間隔を制御できるようになりました。SQL Server 2008 R2 までは、NEAR オプションを使用して近接しているかどうかを判断するため基準は、二つの単語の間隔が 8 単語以内と決定されていてカスタマイズすることができませんでした。SQL Server 2012 からは、NEAR オプションで近接の判断基準をユーザが決定することができます。たとえば次のクエリを実行すると「test」と「Space」の間隔が5単語以内であれば、近接していると判断されます。

SELECT * FROM table1 WHERE CONTAINS(*, ‘NEAR((test, Space), 5))

 また、クエリを次のように変更すると2単語以内の間隔を近接していると判断します。

SELECT * FROM table1 WHERE CONTAINS(*, ‘NEAR((test, Space), 2))

 つづいて、もうひとつの機能拡張です。二つの単語の検索対象内での順序を条件に含めることができるようになりました。次のように指定すると、まず「test」という単語が検索対象内に存在し、そのあとで「Space」が検出されるようなデータのみを抽出します。

SELECT * FROM table1 WHERE CONTAINS(*, ‘NEAR((test, Space), 5),TRUE)

一方、次のようにクエリを修正すると二つの単語が検出される順序は無視され、「test」と「Space」が5単語以内に存在するデータが抽出対象になります。

SELECT * FROM table1 WHERE CONTAINS(*, ‘NEAR((test, Space), 5),FALSE)

次回の連載では、SQL Server 2012フルテキスト検索で強化された機能の紹介を続けます。

お楽しみに!

この記事は参考になりましたか?

  • Facebook
  • Twitter
  • Pocket
  • note
あたらしいSQL Server/Denaliの世界連載記事一覧

もっと読む

この記事の著者

平山理(ヒラヤマオサム)

日本マイクロソフト株式会社
プレミアフィールドエンジニアリング
プレミアフィールドエンジニア日本マイクロソフトの Premier Field Engineering 部で、お客様に SQL Server をスムーズにお使いいただくための様々なお手伝いをしています。Sybase (現 SAP) 勤務時代の 5 年間とマイクロソフトでの 12 年間、データベース道を極めるために精進する毎日です。
二人の娘の父親で...

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

EnterpriseZine(エンタープライズジン)
https://enterprisezine.jp/article/detail/3880 2012/04/12 00:00

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けに、EnterpriseZine Day、Security Online Day、DataTechという、3つのイベントを開催しております。それぞれ編集部独自の切り口で、業界トレンドや最新事例を網羅。最新の動向を知ることができる場として、好評を得ています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング