Maison >développement back-end >tutoriel php >Guide de développement de recherche PHP et Manticore : créer des recherches de cluster efficaces
Guide de développement de PHP et Manticore Search : Création d'une recherche de cluster efficace
Manticore Search est un moteur de recherche en texte intégral hautes performances, qui est un fork du moteur de recherche Sphinx et est conçu pour gérer des ensembles de données à grande échelle et une concurrence élevée. requêtes. Il est très étroitement intégré à PHP et fournit des API et des fonctions riches, permettant aux développeurs de créer facilement des applications de recherche de cluster efficaces.
Cet article expliquera comment utiliser PHP et Manticore Search pour créer une application de recherche de cluster efficace. Nous aborderons les aspects suivants :
Avant de commencer, nous devons d'abord installer Manticore Search. Vous pouvez télécharger le dernier package d'installation sur le site officiel (https://www.manticoresearch.com/) et l'installer en fonction du système d'exploitation que vous utilisez.
En PHP, nous pouvons utiliser l'extension PDO pour nous connecter au Manticore Search Cluster. Tout d'abord, nous devons créer un objet de connexion PDO et spécifier l'adresse de l'hôte, le numéro de port, le nom de la bibliothèque d'index et d'autres informations associées :
$dsn = "mysql:host=127.0.0.1;port=9306;dbname=my_index"; $username = "root"; $password = ""; try { $connection = new PDO($dsn, $username, $password); } catch (PDOException $e) { echo "Connection failed: " . $e->getMessage(); die; }
Manticore Search utilise des index pour stocker et rechercher des données. Nous pouvons utiliser des instructions SQL pour créer des index et définir des types et des attributs de champs :
$createIndexQuery = "CREATE TABLE my_index ( id INTEGER, title TEXT, content TEXT, weight INTEGER ) ENGINE='MANTICORE'"; $connection->query($createIndexQuery);
Nous pouvons également utiliser d'autres instructions SQL pour modifier la structure de l'index, comme l'ajout de champs, la modification des attributs de champ, etc.
La recherche en texte intégral est facile avec Manticore Search. Nous pouvons utiliser le mot-clé MATCH pour spécifier les conditions de recherche et CONTRE pour spécifier les mots-clés de recherche :
$searchQuery = "SELECT * FROM my_index WHERE MATCH('keyword')"; $result = $connection->query($searchQuery); $rows = $result->fetchAll(PDO::FETCH_ASSOC);
Le mot-clé ici peut être un seul mot ou une combinaison de plusieurs mots. Manticore Search renverra des résultats liés aux mots-clés.
Nous pouvons utiliser la clause ORDER BY pour trier les résultats de recherche :
$searchQuery = "SELECT * FROM my_index WHERE MATCH('keyword') ORDER BY weight DESC"; // 执行查询并获取结果
De plus, nous pouvons également utiliser la clause WHERE pour filtrer les résultats de recherche :
$searchQuery = "SELECT * FROM my_index WHERE MATCH('keyword') AND category='news'"; // 执行查询并获取结果
En plus de la fonction de recherche en texte intégral de base, Manticore Search fournit également de nombreuses fonctions de recherche avancées, telles que la recherche par caractères génériques, la recherche floue, la recherche par plage, etc. Nous pouvons utiliser des opérateurs tels que LIKE, REGEXP et BETWEEN pour réaliser ces fonctions.
Voici quelques exemples de codes :
$searchQuery = "SELECT * FROM my_index WHERE title LIKE '%keyword%'"; $searchQuery = "SELECT * FROM my_index WHERE title REGEXP '[A-Za-z]+word'"; $searchQuery = "SELECT * FROM my_index WHERE date BETWEEN '2022-01-01' AND '2022-12-31'";
Manticore Search prend en charge le déploiement de cluster pour améliorer les performances et l'évolutivité de la recherche. Nous pouvons utiliser la commande suivante pour gérer le cluster :
sudo indexer --rotate --all sudo searchd --stop sudo searchd --start
De plus, nous pouvons également utiliser le mot-clé EXPLAIN pour optimiser les performances des requêtes et afficher les plans d'exécution des requêtes et l'utilisation de l'index.
Résumé
Grâce à cet article, nous avons appris à utiliser PHP et Manticore Search pour créer une application de recherche de cluster efficace. Nous avons appris à installer Manticore Search, à nous connecter au cluster, à créer et gérer des index, à effectuer des requêtes de recherche en texte intégral et à implémenter des fonctionnalités de recherche avancées.
Manticore Search est un moteur de recherche puissant et facile à utiliser, très étroitement intégré à PHP. En utilisant pleinement les fonctions et les API de Manticore Search, nous pouvons créer des applications de recherche de cluster efficaces pour répondre à divers besoins de recherche. J'espère que cet article vous sera utile !
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!