Recherche en texte intégral à l'aide de Solr en PHP
Solr est un moteur de recherche basé sur Lucene qui peut être utilisé pour mettre en œuvre une recherche en texte intégral. L'utilisation de Solr en PHP pour la recherche en texte intégral peut nous aider à interroger rapidement des données pertinentes via des mots-clés et à améliorer la précision et la fiabilité des résultats de recherche. Cet article explique comment utiliser Solr en PHP pour la recherche en texte intégral.
1. Installation et configuration de Solr
Tout d'abord, nous devons installer Solr et l'extension Solr de PHP sur le serveur. Pour les étapes d'installation de Solr, veuillez vous référer à la documentation officielle de Solr. L'extension Solr de PHP peut être installée à l'aide de la commande suivante :
sudo pecl install solr
Une fois l'installation terminée, vous devez ajouter l'extension Solr au fichier de configuration PHP. , comme dans Ubuntu Vous pouvez modifier le fichier /etc/php/7.0/apache2/php.ini et ajouter le contenu suivant :
extension=solr.so
Après avoir enregistré et quitté le fichier, redémarrez le serveur Apache pour faire la configuration prend effet.
2. Créer un index Solr
Après avoir installé Solr et l'extension Solr de PHP, nous devons créer un index Solr. Un index Solr est une table de recherche rapide correspondant à toutes les données d'une table de base de données, utilisée pour prendre en charge la recherche en texte intégral. Les étapes pour créer un index Solr sont les suivantes :
- Créer un nouveau noyau Solr
sudo su - solr -c "/opt/solr/bin/solr create -c mycore"
"mycore" est un nom similaire au index, vous pouvez vous-même définir. Après une création réussie, vous pouvez le visualiser en visitant http://localhost:8983/solr/#/mycore.
- Définir les champs d'index dans Solr
Dans Solr, nous devons définir les champs requis pour l'indexation. Par exemple, si nous souhaitons rechercher le titre et le contenu du corps d’un article, nous devons définir respectivement les champs de titre et de contenu.
peut être défini dans l'interface de gestion Solr : cliquez sur le bouton "Schéma" à gauche, cliquez sur "Ajouter un champ" sous l'onglet "Champs", renseignez le nom du champ comme "titre", Champ tapez Pour "text_cn" (text_cn est un analyseur chinois pour Solr), cliquez sur le bouton "Enregistrer" pour enregistrer.
De même, vous pouvez créer un champ nommé "content" et le type est également "text_cn".
- Importer des données dans l'index Solr
Après avoir créé le noyau Solr et défini les champs d'index, nous devons importer les données dans la base de données dans l'index Solr. Ceci peut être réalisé en écrivant un script PHP.
Ce qui suit est un exemple de code :
<?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(); ?>
Dans le code ci-dessus, vous devez remplacer $username, $password, $dbname, $options et mycore dans le SolrClient( ) méthode avec les valeurs correspondantes.
Après avoir exécuté ce script, l'index Solr contiendra les données dans la base de données et les données associées pourront être recherchées par mots-clés.
3. Recherche en texte intégral via Solr
Une fois que l'index contient des données, vous pouvez utiliser Solr pour effectuer une recherche en texte intégral. La fonction de recherche peut être implémentée en communiquant avec le serveur Solr via une application PHP. Le langage de requête fourni par Solr est Solr Query Language (SOLRQ). La syntaxe de requête est utilisée pour comparer les données demandées avec les données indexées par Solr afin d'identifier quels documents contiennent le texte requis.
Ce qui suit est un exemple de code de recherche simple :
<?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'] . " "; } ?>
Dans le code ci-dessus, vous devez remplacer $options et mycore et "keywords" dans $query par les valeurs correspondantes .
Dans la syntaxe de recherche, titre:mot-clé signifie rechercher des documents dont le titre contient « mot-clé ». Si vous souhaitez rechercher du contenu, vous pouvez utiliser le formulaire content:mot-clé. Vous pouvez également effectuer davantage d'opérations de modification sur la requête, telles qu'une requête floue, une requête par plage, une requête booléenne, etc.
4. Résumé
Cet article présente les étapes de base de l'utilisation de Solr en PHP pour la recherche en texte intégral. Tout d'abord, importez les données de la base de données dans l'index Solr en créant un index Solr, puis communiquez avec le serveur Solr via l'application PHP pour effectuer des recherches et d'autres opérations. Dans les applications pratiques, il existe davantage d'attributs fonctionnels et d'options de configuration qui doivent être appris et utilisés. J'espère que cet article pourra être utile à tout le monde !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Les capacités de recherche en texte intégral d'InNODB sont très puissantes, ce qui peut considérablement améliorer l'efficacité de la requête de la base de données et la capacité de traiter de grandes quantités de données de texte. 1) INNODB implémente la recherche de texte intégral via l'indexation inversée, prenant en charge les requêtes de recherche de base et avancées. 2) Utilisez la correspondance et contre les mots clés pour rechercher, prendre en charge le mode booléen et la recherche de phrases. 3) Les méthodes d'optimisation incluent l'utilisation de la technologie de segmentation des mots, la reconstruction périodique des index et l'ajustement de la taille du cache pour améliorer les performances et la précision.
