Maison >développement back-end >tutoriel php >Comment utiliser PHP et Elasticsearch pour réaliser l'agrégation et l'analyse des résultats

Comment utiliser PHP et Elasticsearch pour réaliser l'agrégation et l'analyse des résultats

WBOY
WBOYoriginal
2023-07-17 13:05:101256parcourir

Comment utiliser PHP et Elasticsearch pour réaliser l'agrégation et l'analyse des résultats

Introduction :
Avec le développement rapide d'Internet et des technologies de l'information, la croissance explosive du volume de données rend le stockage, le traitement et l'analyse des données de plus en plus importants. En tant que moteur de recherche et d'analyse distribué open source, Elasticsearch dispose de puissantes capacités de récupération de texte intégral, d'analyse en temps réel et d'agrégation de données, et a été largement utilisé dans divers secteurs majeurs. Dans cet article, nous présenterons comment utiliser PHP et Elasticsearch pour implémenter l'agrégation et l'analyse des résultats, et donnerons des exemples de code correspondants.

1. Préparation :

  1. Installer et configurer Elasticsearch
    Avant d'utiliser Elasticsearch, vous devez installer et configurer le serveur Elasticsearch. Vous pouvez vous référer à la documentation officielle d'Elasticsearch pour l'installation et la configuration.
  2. Installer et configurer les bibliothèques PHP
    En PHP, nous devons utiliser des bibliothèques qui fonctionnent sur Elasticsearch. Vous pouvez utiliser l'outil de gestion de packages Composer pour installer les bibliothèques PHP requises, telles que la bibliothèque elasticsearch/elasticsearch.

2. Connectez-vous à Elasticsearch :
Tout d'abord, nous devons nous connecter au serveur Elasticsearch. Vous pouvez utiliser la classe Elasticsearch fournie par la bibliothèque elasticsearch/elasticsearch pour implémenter la connexion :

require 'vendor/autoload.php';
$hosts = [
    'localhost:9200' // Elasticsearch服务端的地址和端口
];
$client = ElasticsearchClientBuilder::create()
             ->setHosts($hosts)
             ->build();

3. Indexation et stockage des données :
Dans Elasticsearch, l'index est un concept similaire à une table dans une base de données, utilisée pour stocker et trouver des données. Tout d’abord, nous devons créer un index pour nos données et spécifier le mappage correspondant.

  1. Créez un index :
    Utilisez la méthode indices()->create() de la classe Elasticsearch pour créer un nouvel index :
$params = [
    'index' => 'my_index', // 索引名称
    'body'  => [
        'settings' => [
            'number_of_shards' => 1,
            'number_of_replicas' => 0
        ],
    ],
];
$response = $client->indices()->create($params);
  1. Créez un mappage :
    Le mappage dans l'index définit la structure et les propriétés du document. Vous pouvez utiliser la méthode indices()->putMapping() pour définir le mappage dans un index existant :
$params = [
    'index' => 'my_index', // 索引名称
    'type' => 'my_type', // 文档类型
    'body' => [
        'my_type' => [
            'properties' => [
                'title' => [
                    'type' => 'text'
                ],
                'content' => [
                    'type' => 'text'
                ],
                'date' => [
                    'type' => 'date'
                ],
                // 其他字段...
            ]
        ]
    ]
];
$response = $client->indices()->putMapping($params);
  1. Données de stockage :
    Utilisez la méthode index() pour insérer des données dans l'index :
$params = [
    'index' => 'my_index', // 索引名称
    'type' => 'my_type', // 文档类型
    'body' => [
        'title' => 'Elasticsearch', // 文档字段及对应的值
        'content' => 'Elasticsearch is a distributed, RESTful search and analytics engine.',
        'date' => '2021-01-01'
        // 其他字段...
    ]
];
$response = $client->index($params);

4. Agrégation et analyse des résultats :
Dans Elasticsearch, l'agrégation est une fonction puissante qui peut effectuer des opérations telles que le regroupement et les statistiques sur les données. Vous pouvez utiliser la méthode search() pour implémenter des fonctions d'agrégation et d'analyse.

  1. Recherche et agrégation :
    Utilisez la méthode search() pour réaliser les fonctions de recherche et d'agrégation. En transmettant les paramètres de requête et les paramètres d'agrégation correspondants, vous pouvez obtenir les résultats requis :
$params = [
    'index' => 'my_index', // 索引名称
    'type' => 'my_type', // 文档类型
    'body' => [
        'query' => [ // 查询参数
            'match' => [
                'content' => 'Elasticsearch'
            ]
        ],
        'aggs' => [ // 聚合参数
            'group_by_date' => [
                'date_histogram' => [
                    'field' => 'date',
                    'interval' => 'month'
                ]
            ],
            // 其他聚合参数...
        ]
    ]
];
$response = $client->search($params);
  1. Analyse des résultats :
    Grâce à l'analyse. Les résultats agrégés peuvent obtenir les données requises. Vous pouvez utiliser la méthode getResponse() pour obtenir les résultats de réponse complets, puis les analyser :
$response = $client->search($params);
$result = $response['aggregations']['group_by_date']['buckets'];
foreach($result as $bucket) {
    $date = $bucket['key_as_string'];
    $count = $bucket['doc_count'];
    // 打印结果...
}

Conclusion :
Grâce à l'exemple de code ci-dessus, nous pouvons utiliser PHP et Elasticsearch pour obtenir le résultat. fonction d’agrégation et d’analyse. Bien entendu, Elasticsearch a des fonctions et des utilisations plus complexes. Nous espérons que les lecteurs pourront les explorer davantage et les utiliser de manière flexible pour répondre aux besoins de différents scénarios. J'espère que cet article sera utile aux lecteurs, merci d'avoir lu !

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn