序文以前、プロジェクトの要件により、キーワードに基づいてチャット記録を検索する必要がありました。これは検索エンジンの機能ではないでしょうか? そこで最初に思いついたのがElasticSearch分散検索エンジンだったのですが、何らかの理由で会社のサーバーリソースが比較的逼迫しており、ElasticSearchサービスを展開するための余分なマシンがありませんでした。また、オンライン時間も比較的逼迫しており、データ量もそれほど多くありませんでした。そこで、MySQLの全文インデックスを思いつきました。 導入実際、MySQL は長い間フルテキスト インデックスをサポートしてきましたが、サポートされていたのは英語の検索のみでした。バージョン 5.7.6 以降、MySQL には中国語、日本語、韓国語の単語分割をサポートする ngram フルテキスト パーサーが組み込まれています。 Mysql フルテキスト インデックスは、転置インデックスの原理を採用しています。転置インデックスでは、キーワードが主キーとなり、各キーワードはキーワードが出現する一連のファイルに対応します。このように、ユーザーがキーワードを検索すると、ソート プログラムは逆インデックス内でキーワードを見つけ、そのキーワードを含むすべてのファイルをすぐに見つけることができます。 この記事はMySQL 8.0に基づいてテストされており、データベースエンジンはInnoDBを使用しています。 ngram全文パーサーngram は、テキスト内の n 個の連続した単語のシーケンスです。 ngram フルテキスト パーサーは、各単語が n 個の連続した単語のシーケンスであるテキストをトークン化できます。たとえば、ngram フルテキスト パーサーを使用して「你好靓仔」をセグメント化します。 n=1: 「あなた」、「いい人」、「かわいい」、「男の子」 n=2: 「こんにちは」、「とてもかわいい」、「ハンサムな男の子」 n=3: 「あなたはとてもきれいですね」、「あなたはとてもきれいですね」 n=4: 「こんにちは、ハンサムな男の子」 MySQL では、グローバル変数 次のコマンドを実行すると、MySQL のデフォルトの 'ngram_token_size' のような変数を表示する グローバル変数 1. mysqld コマンドの起動時に指定します。 mysqld --ngram_token_size=2 2. Mysql 構成ファイル my.ini を変更し、最後にパラメータの行を追加します。 nグラムトークンサイズ=2 全文インデックスを作成する1. テーブルを構築するときにフルテキストインデックスを作成する テーブル「記事」を作成します( `id` bigint NOT NULL、 `url` varchar(1024) COLLATE utf8mb4_general_ci NOT NULL DEFAULT '', `title` varchar(256) COLLATE utf8mb4_general_ci NOT NULL DEFAULT '', `source` varchar(32) COLLATE utf8mb4_general_ci DEFAULT '' `keywords` varchar(32) COLLATE utf8mb4_general_ci デフォルト NULL, `publish_time` タイムスタンプ NULL デフォルト NULL、 主キー (`id`)、 フルテキストキー `title_index` (`title`) とパーサー `ngram` ) エンジン=InnoDB デフォルト文字セット=utf8mb4 照合=utf8mb4_general_ci; 2. テーブル変更方法 ALTER TABLE article に FULLTEXT INDEX title_index(title) を追加し、PARSER ngram を追加します。 3. インデックス作成メソッドを通じて PARSER ngram を使用して article (title) に FULLTEXT インデックス title_index を作成します。 検索方法1. 自然言語検索(自然言語モード)自然言語モードは、MySQL のデフォルトの全文検索モードです。自然言語モードでは演算子を使用できず、キーワードが表示される必要がある、または表示されない必要があるなどの複雑なクエリを指定することはできません。 例 select * from article where MATCH(title) AGAINST ('北京観光' IN NATURAL LANGUAGE MODE); // モードが指定されていない場合は、デフォルトで自然言語モードが使用されます select * from article where MATCH(title) AGAINST ('北京旅游'); このモードでは、「北京 旅行」を検索すると、自然言語に基づいて 2 つのキーワードに分割されるため、「北京」または「旅行」を含むコンテンツを検索できることがわかります。 上記の例では、返される結果は一致度によって自動的にソートされ、最も一致度が高いものが先頭に表示されます。一致度は、負でない浮動小数点数です。 例 // 一致度を確認します。select *、MATCH(title) AGAINST ('Beijing Tourism') as score from article where MATCH(title) AGAINST ('Beijing Tourism' IN NATURAL LANGUAGE MODE); 2. ブール検索(ブールモード)ブール検索モードでは、演算子を使用して、キーワードが表示される必要があるか表示されない必要があるか、キーワードの重みが高いか低いかを指定するなどの複雑なクエリをサポートできます。 例 // 演算子なし // 「デート」または「戦略」を含む select * from article where MATCH(title) AGAINST ('Dating Guide' IN BOOLEAN MODE); // 演算子を使用する // 「デート」を含める必要がありますが、「戦略」を含めることができます select * from article where MATCH(title) AGAINST ('+Dating Guide' IN BOOLEAN MODE); その他の演算子の例: 「デートのヒント」 演算子なし、OR を意味し、「デート」または「戦略」のいずれかを含む 「+デート+戦略」 「+デートのヒント」という単語の両方を含める必要があります 「デート」が含まれている必要がありますが、「戦略」も含まれている場合は一致率が高くなります。 「+デート戦略」 「日付」を含める必要があり、「戦略」を含めることはできません。 「+デート〜戦略」 「デート」は必ず含める必要がありますが、「戦略」も含めると、一致スコアは「戦略」なしの記録よりも低くなります。 '+デート+(>戦略<ヒント)' クエリには、「デート」と「戦略」または「デート」と「スキル」のレコードが含まれている必要がありますが、「デート戦略」は「デートスキル」よりも一致率が高くなります。 「デート*」 クエリには、「Appointment」で始まるレコードが含まれます。 「デートのヒント」 検索する単語を二重引用符で囲みます。効果は「%Dating Guide%」のようになります。 たとえば、「初心者向けのデート戦略」は一致しますが、「デート戦略」は一致しません。 比較する同様のクエリと比較して、フルテキスト インデックスには次の利点があります。
全文検索のパフォーマンスは類似クエリよりも優れています 以下は約50wのデータに基づいたテストです。 // クエリのように select * from article where title like '%北京%'; // フルテキスト インデックス クエリ select * from article where MATCH(title) AGAINST ('北京' IN BOOLEAN MODE); 類似クエリは 1.536 秒、全文インデックス クエリは 0.094 秒と、約 16 倍高速であることがわかります。 要約する全文インデックスを使用すると高速な検索が可能になりますが、インデックスを維持するためのオーバーヘッドも発生します。フィールドの長さが長くなるほど、作成されるフルテキスト インデックスが大きくなり、DML ステートメントのスループットに影響します。データ量が多くない場合は、フルテキストインデックスを使用して検索できます。これは簡単で便利です。ただし、データ量が多い場合は、専用の検索エンジン ElasticSearch を使用して検索することをお勧めします。 MySQL で簡単な検索エンジンを実装するためのサンプルコードに関するこの記事はこれで終わりです。MySQL 検索エンジンに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
>>: Dockerにlogstashをインストールする詳細な手順
概要MySQL の最も強力な機能の 1 つは、データ取得を実行しながらテーブルを結合できることです。...
1. リポジトリファイルを作成するmongodb の公式インストール ドキュメントを参照し、次のスク...
かなり前に実装された機能ですが、クリックすると選択したメニュー項目の背景色が白くなることに気付きまし...
目次1. はじめに2. MVCC (マルチバージョン同時実行制御メカニズム) 2.1 繰り返し読み取...
目次1. 一括更新の方法コンソール出力2. フックがルーティングパラメータを取得する方法実行効果1....
コードをコピーコードは次のとおりです。 <!-- ブラウザがローカル キャッシュからページにア...
デフォルトでは、 /etc/default/docker 設定は有効になりません。docker 環境...
1. MySQLデータベースをインストールする① ダウンロードして解凍し、/opt/softディレク...
プロジェクトには、オンラインで編集する必要があるテーブルがあります。最初は、要素の el-table...
概要私は 1 年以上 Docker を使用しています。最近、サービスをすばやくオーケストレーションし...
目次1. 実施計画の概要2. 実行計画の実践id:選択タイプ:テーブル:タイプ:可能なキー:鍵:キー...
目次チェーン呼び出し小さなケースチェーン呼び出しjQuery オブジェクトが任意のメソッド (ノード...
エラー 1290 (HY000) : MySQL サーバーは –secure-file-priv オ...
目次1. シナリオ2. 解決策3. 結論4. 参考文献1. シナリオ日常の開発およびテスト作業には ...
目次vue2.xプレコンセプト:ルーティングフックのカテゴリルーティングとコンポーネントの概念(フッ...