これはPGroonga 1.X用のドキュメントです。新しいPGroongaを使っているならPGroonga 2.xのドキュメントを見てください。
%%
演算子この演算子は1.2.0から非推奨です。代わりに&@
演算子を使ってください。
%%
は1つのキーワードで全文検索を実行します。
column %% keyword
column
は検索対象のカラムです。型はtext
型、text[]
型、varchar
型のどれかです。
keyword
は全文検索で使うキーワードです。column
がtext
型またはtext[]
型ならkeyword
はtext
型です。column
がvarchar
型ならkeyword
はvarchar
型です。
この演算子を使うには次のどれかの演算子クラスを指定する必要があります。
pgroonga.text_full_text_search_ops
:text
のデフォルト
pgroonga.text_array_full_text_search_ops
:text[]
のデフォルト
pgroonga.varchar_full_text_search_ops
:varchar
用
pgroonga.text_full_text_search_ops_v2
:text
用
pgroonga.text_array_full_text_search_ops_v2
:text[]
用
pgroonga.varchar_full_text_search_ops_v2
:varchar
用
例に使うサンプルスキーマとデータは次の通りです。
CREATE TABLE memos (
id integer,
content text
);
CREATE INDEX pgroonga_content_index ON memos USING pgroonga (content);
INSERT INTO memos VALUES (1, 'PostgreSQLはリレーショナル・データベース管理システムです。');
INSERT INTO memos VALUES (2, 'Groongaは日本語対応の高速な全文検索エンジンです。');
INSERT INTO memos VALUES (3, 'PGroongaはインデックスとしてGroongaを使うためのPostgreSQLの拡張機能です。');
INSERT INTO memos VALUES (4, 'groongaコマンドがあります。');
%%
演算子を使うと1つキーワードで全文検索できます。
SELECT * FROM memos WHERE content %% '全文検索';
-- id | content
-- ----+---------------------------------------------------
-- 2 | Groongaは日本語対応の高速な全文検索エンジンです。
-- (1 row)
複数のキーワードで全文検索したいときやAND/ORを使った検索をしたいときは&@~
演算子を使います。
複数のキーワードでOR全文検索をしたいときは&@|
演算子を使います。