facebook twitter hatena line email

Mroonga/検索

提供: 初心者エンジニアの簡易メモ
2015年6月2日 (火) 15:43時点におけるAdmin (トーク | 投稿記録)による版 (ページの作成:「 ==検索テスト== CREATE TABLE diaries ( id INT PRIMARY KEY AUTO_INCREMENT, content VARCHAR(255), FULLTEXT INDEX (content) ) ENGINE = mroonga DEFAULT CHARSET u...」)

(差分) ←前の版 | 最新版 (差分) | 次の版→ (差分)
移動: 案内検索

検索テスト

CREATE TABLE diaries (
 id INT PRIMARY KEY AUTO_INCREMENT,
 content VARCHAR(255),
 FULLTEXT INDEX (content)
) ENGINE = mroonga DEFAULT CHARSET utf8;
insert into diaries (content) values ("明日は晴れです");
insert into diaries (content) values ("明日は曇りです");
select * from diaries where match(content) against('晴れ');
| id | content               |
+----+-----------------------+
|  3 | 明日は晴れです        |

スコア表示

select *,match(content) against('明日') AS score from diaries where match(content) against('明日') order by match(content) against('明日');
| id | content               | score  |
+----+-----------------------+--------+
|  3 | 明日は晴れです        | 262145 |
|  4 | 明日は曇りです        | 262145 |


複数ワードを含む文章の検索方法

×select * from diaries where match(content) against('php開発');
○select * from diaries where match(content) against('php') AND match(content) against('開発');

mecabであらかじめ検索ワードを分かち書きをして、ANDでつなげて検索する

パーサをmecabへ変更

mysql5.5ではmy.cnfを変更することでパーサを変更はできない。

[mysqld]
mroonga_default_parser=TokenMecab

以下のようにindexにコメントをつけなければならない。

ALTER TABLE diaries DROP INDEX idx_name1; 
ALTER TABLE diaries ADD FULLTEXT INDEX idx_name1(name) COMMENT 'parser "TokenMecab"'

create tableではこのように

CREATE TABLE ~
FULLTEXT KEY `idx_name` (`name`) COMMENT 'parser "TokenMecab"'

normalizerも同時に指定する方法

CREATE TABLE ~
FULLTEXT KEY `idx_name` (`name`) COMMENT 'parser "TokenMecab", normalizer "NormalizerAuto"'

参考 http://dfcblog.net/2013/02/mroonga%E3%81%A7mecab%E3%82%92%E4%BD%BF%E3%81%86%E9%9A%9B%E3%81%AB%E3%81%AF%E3%81%BE%E3%81%A3%E3%81%9F%E8%A9%B1.html


log

$ sudo tail -f /var/lib/mysql/groonga.log
$ sudo tail -f /var/log/message | grep mroonga