Java API開発における全文検索にSolrを使用する
インターネットの発達と情報の爆発的な増加に伴い、Web ページ、文献、日常生活などから得られる情報は膨大な量に達しており、効率的な方法が必要です。処理して管理します。全文検索は、キーワードやフレーズを通じて必要な情報を見つけて抽出するための非常に効率的で一般的に使用される方法であり、Solr は全文検索の開発に非常に適したツールです。
この記事では、Solr の基本概念と、Java API 開発における全文検索に Solr を使用する方法を紹介します。
1. Solr の概要
Solr は本質的にオープン ソースのエンタープライズ検索プラットフォームであり、Apache Lucene Java ライブラリに基づいており、いくつかの便利な REST API を提供します。 Solr の公式紹介によると、主に次の機能が含まれています。
- 全文検索
- リアルタイム検索
- ウェブサイト検索
- 分散検索
- データベース統合
- 複数のファイル形式の解析
- 複数のファイル形式のエクスポート
- 外部構成
As a エンタープライズレベルの検索プラットフォームである Solr は、非常に完全な検索機能と柔軟な構成方法を提供するため、実際の開発で検索モジュールの開発が容易になります。以下では、Java API 開発における全文検索に Solr を使用する方法に焦点を当てます。
2. 全文検索に Solr を使用する
2.1 Solr のインストール
まず、Solr をローカル環境またはサーバーにインストールする必要があります。 Solr は、Solr をインストールして実行するための非常に便利な方法を公式に提供しています:
- Solr のダウンロード アドレス: https://lucene.apache.org/solr/downloads.html。
- ファイルを解凍します: tar -zxvf solr-x.x.x.zip。
- 解凍されたフォルダー「cd solr-x.x.x」を入力します。
- Solr の開始: bin/solr start。
2.2 Solr コアの作成とスキーマの定義
Solr コアは Solr の中核となる概念であり、データ インデックスや検索リクエストの処理を含む独立した検索環境に相当します。 Solr では、複数のコアを作成でき、各コアは独立した構成とデータ セットを持つことができます。
Solr では、最初にコアを作成し、次に検索用のスキーマを定義する必要があります。スキーマはデータ フィールド、タイプ、インデックス、その他の属性を定義し、検索の効率と精度に影響します。
Solr 独自のスキーマまたはユーザー定義のスキーマを使用して、検索に必要なフィールド属性を定義できます。ここでは、Solr のデフォルト スキーマの使用方法を紹介します。
Solr 独自のデフォルト スキーマを使用する:
-
コアを作成する:
bin/solr create_core -c <core name>
ログイン後にコピーログイン後にコピー 作成されたフィールドをすべてクリアする:
curl http://localhost:8983/solr/<core name>/schema -H 'Content-type:application/json' -d '{"delete-all-fields":{}}'
ログイン後にコピーフィールドの追加:
curl http://localhost:8983/solr/<core name>/schema -H 'Content-type:application/json' -d ' { "add-field":{ "name":"field_name", "type":"string", "stored":true } }'
ログイン後にコピー- Solr サービスの再起動
ユーザー定義のスキーマの使用:
ユーザーはスキーマをカスタマイズして、さまざまなアプリケーションのニーズに対応し、Solr はスキーマ API を提供します。作成者が簡単にスキーマを追加できるようにします。
コアの作成:
bin/solr create_core -c <core name>
ログイン後にコピーログイン後にコピーフィールドの追加:
- フィールド タイプの追加:
フィールドを追加Solr サーバー content_type を application/json に設定して POST リクエストを送信します。
{ "add-field-type": { "name":"test_fieldType","class":"solr.TextField","indexAnalyzer":{ "tokenizer":{ "class":"solr.StandardTokenizerFactory" },"filters":[ { "class":"solr.StopFilterFactory", "ignoreCase":true, "words":"stopword.txt", "format":"snowball", "enablePositionIncrements":true },{ "class":"solr.SnowballPorterFilterFactory", "language":"English" } ], "queryAnalyzer":{ "tokenizer":{ "class":"solr.StandardTokenizerFactory" },"filters":[ { "class":"solr.StopFilterFactory", "ignoreCase":true, "words":"stopword.txt", "format":"snowball", "enablePositionIncrements":true },{ "class":"solr.SnowballPorterFilterFactory", "language":"English" } ] } } }
ログイン後にコピー- フィールド (タイトル) を追加:
{ "add-field": { "name": "title", "type": "text_en", "stored": true } }
ログイン後にコピーフィールドの後に応答が返されます。正常に追加されました。
- フィールド タイプの追加:
Solr config でこのスキーマを指定します:
${core}/conf ディレクトリに入って solrconfig.xml を変更し、次のコードを追加します:
<schemaFactory class="ClassicIndexSchemaFactory"/> <schema name="schema_name" version="1.5"> <field name="title" type="text_en" indexed="true" stored="true" /> </schema>
ログイン後にコピー
2. Java API で Solr を使用して全文検索を行う
次に、Solr の Java API を使用して Java Web アプリケーションで全文検索を行う方法を紹介します。
- SolrJ 依存関係の追加
Maven プロジェクトでは、SolrJ 依存関係を追加する必要があります。Solr は非常に便利な依存関係を公式に提供しています:
<dependency> <groupId>org.apache.solr</groupId> <artifactId>solr-solrj</artifactId> <version>8.2.0</version> </dependency>
- SolrJ を使用してコード内を検索する
Java コードでは、SolrJ が提供する QueryResponse と SolrClient を使用して検索操作を実行できます。クエリされたデータは、キーと値のペアとして表示できます。
まず、SolrClient のインスタンスを作成する必要があります。 SolrJ では、SolrClient は Solr のクライアントであり、Solr REST API を直接呼び出すメソッドを提供します。
String solrUrl = "http://localhost:8983/solr/core_name"; SolrClient solr = new HttpSolrClient.Builder(solrUrl).build();
次に、SolrQuery オブジェクトを作成する必要があります。これは、検索キーワード、並べ替えルール、フィルター条件などの検索パラメーターを設定するために使用されます。
SolrQuery query = new SolrQuery(); query.setQuery("keyword"); query.setStart(0); query.setRows(10); query.setSort("sort_field", SolrQuery.ORDER.asc); query.addFilterQuery("filter_field:filter_value");
最後に、solr.query(query) メソッドを通じて検索を実行できます。返される QueryResponse には、検索結果と関連するメタデータ情報が含まれています。 response.getResults() メソッドを通じて検索結果リストを取得する必要があります。
QueryResponse response = solr.query(query); SolrDocumentList results = response.getResults();
実際の開発では、必要に応じて検索結果をJSON形式やJavaオブジェクトに変換するなどの二次処理を行うこともできます。
for (SolrDocument result : results) { String id = (String) result.getFieldValue("id"); String title = (String) result.getFieldValue("title"); String content = (String) result.getFieldValue("content"); // 将搜索结果转换为 Java 实体类 SearchResult item = new SearchResult(id, title, content); // 或将搜索结果转换为 JSON 字符串 String json = new ObjectMapper().writeValueAsString(result); }
上記は、Java API 開発における全文検索に Solr を使用する基本的なプロセスです。 Solr は非常に完全な検索機能と Java API サポートを提供するため、効率的で正確な検索モジュールを簡単に開発して、ユーザーに優れた検索エクスペリエンスを提供できます。
以上がJava API開発における全文検索にSolrを使用するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

Java での日付までのタイムスタンプに関するガイド。ここでは、Java でタイムスタンプを日付に変換する方法とその概要について、例とともに説明します。

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

カプセルは3次元の幾何学的図形で、両端にシリンダーと半球で構成されています。カプセルの体積は、シリンダーの体積と両端に半球の体積を追加することで計算できます。このチュートリアルでは、さまざまな方法を使用して、Javaの特定のカプセルの体積を計算する方法について説明します。 カプセルボリュームフォーミュラ カプセルボリュームの式は次のとおりです。 カプセル体積=円筒形の体積2つの半球体積 で、 R:半球の半径。 H:シリンダーの高さ(半球を除く)。 例1 入力 RADIUS = 5ユニット 高さ= 10単位 出力 ボリューム= 1570.8立方ユニット 説明する 式を使用してボリュームを計算します。 ボリューム=π×R2×H(4

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

Java は、初心者と経験豊富な開発者の両方が学習できる人気のあるプログラミング言語です。このチュートリアルは基本的な概念から始まり、高度なトピックに進みます。 Java Development Kit をインストールしたら、簡単な「Hello, World!」プログラムを作成してプログラミングを練習できます。コードを理解したら、コマンド プロンプトを使用してプログラムをコンパイルして実行すると、コンソールに「Hello, World!」と出力されます。 Java の学習はプログラミングの旅の始まりであり、習熟が深まるにつれて、より複雑なアプリケーションを作成できるようになります。

Spring Bootは、Java開発に革命をもたらす堅牢でスケーラブルな、生産対応のJavaアプリケーションの作成を簡素化します。 スプリングエコシステムに固有の「構成に関する慣習」アプローチは、手動のセットアップを最小化します。
