MySQLで全文検索を行いたく、色々と調べ、試行錯誤をしたのですが
どうしてもできないので、mysqlでの全文検索のやり方がわかるかたがいらっしゃいましたら
お教え願えますでしょうか。
私がやったこと
0。Mysqlのバージョン 5.5.23をインスコ my.confにft_min_word_len=1を追加 mysql再起動
1。MyISAM型のbookテーブルを作成(utf8_general_ciでとりあえず idとsearch_wordsという2カラムのみ idをprimaryに設定)
2。検索対象であるsearch_wordsをFulltext型に変換
sql> alter table book add fulltext( search_words );
3。データを登録
insert into book (id, search_word) value (1, '夏目漱石 こころ natsume souseki kokoro BOOK-NO-012 時は明治末期。夏休みに鎌倉へ旅行をしていた「私」は鎌倉に来ていた「先生」と出会い交流を始め東京に帰った後も先生の家に出入りするようになる。先生は奥さんと静かに暮らしていた。先生は私に何度も謎めいた、そして教訓めいたことを言う。私は、先生に過去を打ち明けるように迫ったところ来るべき時に過去を話すことを約束した。');
4。mecabで分かち書きした、「夏目」「漱石」をスペースで区切った文字で検索
っがしかし、検索結果が帰ってこない
実行してみたSQL
select * from book where match( search_word ) against( '夏目 漱石' IN BOOLEAN MODE);
select * from book where match( search_word ) against( '+夏目 +漱石' IN BOOLEAN MODE);
select * from book where match( search_word ) against( '"夏目 漱石"' IN BOOLEAN MODE);
select * from book where match( search_word ) against( '"+夏目 +漱石"' IN BOOLEAN MODE);
select * from book where match( search_word ) against( '"+夏目 +漱石"' IN BOOLEAN MODE);
select * from book where match( search_word ) against( '"*夏目 *漱石"' IN BOOLEAN MODE);
select * from book where match( search_word ) against( '"*夏目* *漱石*"' IN BOOLEAN MODE);
「夏目漱石」とひとくくりにした文字列で検索すると、レコードが帰ってきます
また、against( 'natsume souseki' IN BOOLEAN MODE); も帰ってきます
実際にやってみたいことは、上記の文章で「先生」「鎌倉」「私」「夏目」の4語で検索すると
上記のレコードが帰ってくるということがやりたいですのですが、
select * from book where match( search_word ) against( '夏目 先生 鎌倉 私' IN BOOLEAN MODE);
のSQLや対象文字列に+や*を付けたものを実行しても引っかかりませんでした。
私が行った設定/sqlに不備がございましたらご指摘/ご指導いただけませんでしょうか。
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL 書籍の内容はまともでしょうか? 1 2023/01/22 03:07
- MySQL 共通点はあります。何が違うのでしょうか? 1 2023/01/27 05:22
- MySQL PhpMyAdminで作成して実行せよ。 東京23区を、皇居を中心とした4つのエリア(南東, 南西, 1 2023/06/11 11:58
- 邦楽 aiがいくら進化したところで、バンドや歌手が歌を作成して、歌を声までそっくりに歌うのは不可能 4 2023/07/17 07:42
- Oracle SQL update方法 2 2022/06/22 14:07
- Access(アクセス) アクセス where句を使用して複数条件抽出をするには 2 2022/08/29 13:24
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- Access(アクセス) アクセス 有効なフィールド名、または式として認識できませんのエラー 3 2022/08/19 11:53
- 英語 Results: In total, 5,963 titles were identified wi 4 2022/12/29 21:29
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
副問合せの書き方について
-
sqlで、600行あるテーブルを100...
-
書籍の内容はまともでしょうか?
-
SQLサーバから、項目の属性(型...
-
阪急三番街 ATM(ゆうちょ)は...
-
【MySQL】本当に困っているので...
-
DataTableで重複行を削除したい
-
SQL Left Join で重複を排除す...
-
Unionした最後にGROUP BYを追加...
-
1対多結合で多を絞り込み条件と...
-
php+mysqlで複数選択削除について
-
PL/SQLの変数について
-
[MySQL] UNIQUE制約の値を更新...
-
LAST_INSERT_IDで同時にアクセ...
-
Access パラメータクエリをcsv...
-
画像とカテゴリーを出力したい...
-
マイクラPC版のコマンドで効率...
-
Mysql でレコードを追加した時...
-
VMwareがCDドライブを認識する...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
select文のwhere句に配列を入れ...
-
selectした大量データをinsert...
-
センノシド異性体構造式
-
Unionした最後にGROUP BYを追加...
-
insertを高速化させたい
-
SQLにて特定の文字を除いた検索...
-
マイクラPC版のコマンドで効率...
-
ある条件の最大値+1を初番する...
-
inner joinをすると数がおかし...
-
sqlで、600行あるテーブルを100...
-
エクセルの関数について教えて...
-
Access パラメータクエリをcsv...
-
URL と行番号の指定
-
複数テーブルのGROUP BY の使い...
-
PL/SQLの変数について
おすすめ情報