Heim  >  Artikel  >  Backend-Entwicklung  >  Volltextsuche mit Solr in PHP

Volltextsuche mit Solr in PHP

王林
王林Original
2023-06-20 09:12:061749Durchsuche

Solr ist eine Lucene-basierte Suchmaschine, mit der eine Volltextsuche implementiert werden kann. Die Verwendung von Solr in PHP für die Volltextsuche kann uns dabei helfen, relevante Daten schnell anhand von Schlüsselwörtern abzufragen und die Genauigkeit und Zuverlässigkeit der Suchergebnisse zu verbessern. In diesem Artikel wird erläutert, wie Sie Solr in PHP für die Volltextsuche verwenden.

1. Installation und Konfiguration von Solr

Zuerst müssen wir Solr und die Solr-Erweiterung von PHP auf dem Server installieren. Informationen zu den Solr-Installationsschritten finden Sie in der offiziellen Dokumentation von Solr. Die Solr-Erweiterung kann mit dem folgenden Befehl installiert werden:

sudo pecl install solr

Nach Abschluss der Installation müssen Sie die Solr-Erweiterung zur PHP-Konfigurationsdatei hinzufügen Sie können die Datei /etc/php/7.0/apache2/php.ini bearbeiten und den folgenden Inhalt hinzufügen:

extension=solr.so

Nach dem Speichern und Beenden der Datei starten Sie den Apache-Server neu, damit die Konfiguration wirksam wird.

2. Solr-Index erstellen

Nach der Installation von Solr und der Solr-Erweiterung für PHP müssen wir einen Solr-Index erstellen. Ein Solr-Index ist eine schnelle Nachschlagetabelle, die allen Daten in einer Datenbanktabelle entspricht und zur Unterstützung der Volltextsuche verwendet wird. Die Schritte zum Erstellen eines Solr-Index sind wie folgt:

  1. Erstellen Sie einen neuen Solr-Kern.
sudo su - solr -c "/opt/solr/bin/solr create -c mycore"

„mycore“ ist ein Name, der dem Index ähnelt und von Ihnen selbst definiert werden kann. Nach erfolgreicher Erstellung können Sie es unter http://localhost:8983/solr/#/mycore anzeigen.

  1. Indexfelder in Solr definieren

In Solr müssen wir die für die Indizierung erforderlichen Felder definieren. Wenn wir beispielsweise den Titel und den Hauptinhalt eines Artikels durchsuchen möchten, müssen wir die Titel- und Inhaltsfelder entsprechend definieren.

Kann in der Solr-Verwaltungsoberfläche definiert werden: Klicken Sie links auf die Schaltfläche „Schema“, klicken Sie auf der Registerkarte „Felder“ auf „Feld hinzufügen“, geben Sie den Feldnamen als „Titel“ und den Feldtyp als „text_cn“ ein " (text_cn ist ein chinesischer Analysator für Solr), klicken Sie zum Speichern auf die Schaltfläche „Speichern“.

Ähnlich können Sie ein Feld namens „content“ mit dem Typ „text_cn“ erstellen.

  1. Daten in den Solr-Index importieren

Nachdem wir den Solr-Kern erstellt und die Indexfelder definiert haben, müssen wir die Daten in der Datenbank in den Solr-Index importieren. Dies kann durch das Schreiben eines PHP-Skripts erreicht werden.

Das Folgende ist ein Beispielcode:

<?php
$servername = "localhost";
$username = "root";
$password = "password";
$dbname = "mydatabase";

//连接数据库
$conn = new mysqli($servername, $username, $password, $dbname);

//检查连接是否成功
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
} 

//查询数据库中的数据
$sql = "SELECT id, title, content FROM articles";
$result = $conn->query($sql);

//创建Solr客户端
$options = array(
    'hostname' => 'localhost',
    'port'     => 8983,
    'path'     => '/solr/mycore'
);
$client = new SolrClient($options);

//将数据导入到Solr索引中
while($row = $result->fetch_assoc()) {
    $doc = new SolrInputDocument();
    $doc->addField('id', $row['id']);
    $doc->addField('title', $row['title']);
    $doc->addField('content', $row['content']);
    $client->addDocument($doc);
}
$client->commit();
$client->optimize();
echo "Solr索引创建成功!";

//关闭数据库连接
$conn->close();
?>

Im obigen Code müssen Sie $username, $password, $dbname, $options und mycore in der SolrClient()-Methode durch die entsprechenden Werte ersetzen.

Nach der Ausführung dieses Skripts enthält der Solr-Index die Daten in der Datenbank und verwandte Daten können nach Schlüsselwörtern durchsucht werden.

3. Volltextsuche über Solr

Nachdem der Index Daten enthält, können Sie mit Solr eine Volltextsuche durchführen. Die Suchfunktion kann durch Kommunikation mit dem Solr-Server über eine PHP-Anwendung implementiert werden. Die von Solr bereitgestellte Abfragesprache ist Solr Query Language (SOLRQ). Mithilfe der Abfragesyntax werden die angeforderten Daten mit den von Solr indizierten Daten verglichen, um festzustellen, welche Dokumente den erforderlichen Text enthalten.

Das Folgende ist ein einfaches Beispiel für einen Suchcode:

<?php
//创建Solr客户端
$options = array(
    'hostname' => 'localhost',
    'port'     => 8983,
    'path'     => '/solr/mycore'
);
$client = new SolrClient($options);

//查询数据
$query = 'title:关键词';
$query_response = $client->query($query);
$response = $query_response->getResponse();
$docs = $response['response']['docs'];
foreach ($docs as $doc) {
     echo $doc['title'] . "
";
}
?>

Im obigen Code müssen Sie $options und mycore sowie „keywords“ in $query durch die entsprechenden Werte ersetzen.

In der Suchsyntax bedeutet Titel:Schlüsselwort die Suche nach Dokumenten, deren Titel „Schlüsselwort“ enthält. Wenn Sie nach Inhalten suchen möchten, können Sie das Schlüsselwortformular content: verwenden. Sie können auch weitere Änderungsvorgänge an der Abfrage vornehmen, z. B. Fuzzy-Abfrage, Bereichsabfrage, Boolesche Abfrage usw.

4. Zusammenfassung

In diesem Artikel werden die grundlegenden Schritte zur Verwendung von Solr in PHP für die Volltextsuche vorgestellt. Importieren Sie zunächst die Daten in der Datenbank in den Solr-Index, indem Sie einen Solr-Index erstellen, und kommunizieren Sie dann über die PHP-Anwendung mit dem Solr-Server, um Suchvorgänge und andere Vorgänge durchzuführen. In praktischen Anwendungen gibt es weitere Funktionsattribute und Konfigurationsmöglichkeiten, die erlernt und genutzt werden müssen. Ich hoffe, dass dieser Artikel für alle hilfreich sein kann!

Das obige ist der detaillierte Inhalt vonVolltextsuche mit Solr in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn