ホームページ バックエンド開発 PHPチュートリアル PHP Elasticsearch とリレーショナル データベースの統合実践ガイド

PHP Elasticsearch とリレーショナル データベースの統合実践ガイド

Sep 13, 2023 pm 12:49 PM
php elasticsearch リレーショナルデータベース

php Elasticsearch与关系型数据库的集成实践指南

PHP Elasticsearch とリレーショナル データベースの統合のための実践ガイド

はじめに:

インターネットとビッグ データ時代の到来により、データ ストレージは処理方法も常に進化しています。従来のリレーショナル データベースは、大量のデータ、同時読み取りと書き込み、全文検索などのシナリオに直面すると、徐々にいくつかの欠点が明らかになってきました。 Elasticsearch は、リアルタイムの分散検索および分析エンジンとして、その高性能の全文検索、リアルタイム分析、データ視覚化機能により、徐々に業界の注目と利用を集めています。

ただし、実際のアプリケーション シナリオの多くでは、従来のデータ ストレージと処理要件に加え、全文検索やインテリジェントなレコメンデーションなどの機能を考慮するために、既存のリレーショナル データベースを Elasticsearch と統合する必要があることがよくあります。この記事では、PHP 環境で Elasticsearch をリレーショナル データベースと統合する方法を紹介し、具体的なコード例を示します。

パート 1: 環境の準備と構成

  1. Elasticsearch のインストール

まず、Elasticsearch サーバーをインストールして構成する必要があります。対応するインストール パッケージは、公式 Web サイト (https://www.elastic.co/downloads/elasticsearch) からダウンロードできます。インストールが完了したら、Elasticsearch サービスを開始します。

  1. PHP-Elasticsearch ライブラリのインストール

PHP と Elasticsearch 間の対話は、公式に提供されている PHP-Elasticsearch ライブラリを通じて実現できます。 Composer を通じてインストールできます。コマンドは次のとおりです:

composer require elasticsearch/elasticsearch
ログイン後にコピー

インストールが完了したら、対応する名前空間をインポートすることで、Elasticsearch の関連 API を使用できるようになります。

  1. データベースの準備と構成

リレーショナル データベースを準備し、その中に対応するテーブル構造を作成する必要があります。 MySQL を例に挙げると、次の SQL ステートメントを使用して「users」という名前のテーブルを作成できます。

CREATE TABLE users (
  id INT AUTO_INCREMENT PRIMARY KEY,
  name VARCHAR(50),
  age INT,
  email VARCHAR(50)
);
ログイン後にコピー

次に、リレーショナル データベースを構成する必要があります。以下に示すように、config.php ファイルを編集して、データベース接続関連の情報を構成する必要があります。

<?php
  $hostname = 'localhost';
  $username = 'your_username';
  $password = 'your_password';
  $database = 'your_database';
?>
ログイン後にコピー

パート 2: データの同期とインデックスの作成

  1. データの同期

データベース内のデータを Elasticsearch に同期する前に、この機能を実装するための PHP スクリプトを作成する必要があります。以下は簡単な例です:

<?php
  require 'vendor/autoload.php';
  require 'config.php';

  // 建立数据库连接
  $connection = new mysqli($hostname, $username, $password, $database);
  if ($connection->connect_error) {
    die("连接数据库失败:" . $connection->connect_error);
  }

  // 查询数据库数据
  $result = $connection->query("SELECT * FROM users");
  if (!$result) {
    die("查询数据失败:" . $connection->error);
  }

  // 将数据同步到Elasticsearch
  $client = ElasticsearchClientBuilder::create()->build();
  foreach ($result as $row) {
    $params = [
      'index' => 'users',
      'type' => 'user',
      'id' => $row['id'],
      'body' => [
        'name' => $row['name'],
        'age' => $row['age'],
        'email' => $row['email']
      ]
    ];
    $client->index($params);
  }

  echo "数据同步完成。";
?>
ログイン後にコピー

スクリプトを実行すると、データベース内のデータが Elasticsearch の users インデックスに同期されます。

  1. インデックスの作成

インデックスは、リレーショナル データベースのテーブルと同様に、Elasticsearch でデータを編成する方法です。 Elasticsearch でインデックスを設定し、対応するフィールド マッピングを定義する必要があります。

以下はインデックスを作成するサンプル コードです:

<?php
  $params = [
    'index' => 'users',
    'body' => [
      'mappings' => [
        'user' => [
          'properties' => [
            'name' => [
              'type' => 'text'
            ],
            'age' => [
              'type' => 'integer'
            ],
            'email' => [
              'type' => 'keyword'
            ]
          ]
        ]
      ]
    ]
  ];

  $client->indices()->create($params);
?>
ログイン後にコピー

上の例では、users という名前のインデックスを定義します。これには name# が含まれます。 3 つのフィールド: ##、ageemail であり、対応するフィールド マッピングが使用されます。

パート 3: データの検索と表示

    データ検索
データ検索を実行する前に、Elasticsearch を構成し、対応する依存ライブラリを導入する必要があります。以下は簡単な例です:

<?php
  require 'vendor/autoload.php';

  // 连接Elasticsearch
  $client = ElasticsearchClientBuilder::create()->build();

  // 查询用户信息
  $params = [
    'index' => 'users',
    'type' => 'user',
    'body' => [
      'query' => [
        'match' => [
          'name' => 'John'
        ]
      ]
    ]
  ];

  $response = $client->search($params);
  print_r($response);
?>
ログイン後にコピー

上の例では、

name フィールドに「John」を含むユーザー情報をクエリします。

    データ表示
検索結果を取得した後、必要に応じて結果を表示および処理できます。以下に簡単な表示コード例を示します。

<?php
  require 'vendor/autoload.php';

  // 连接Elasticsearch
  $client = ElasticsearchClientBuilder::create()->build();

  // 查询用户信息
  $params = [
    'index' => 'users',
    'type' => 'user',
    'body' => [
      'query' => [
        'match' => [
          'name' => 'John'
        ]
      ]
    ]
  ];

  $response = $client->search($params);
  
  echo "查询到" . $response['hits']['total']['value'] . "条用户信息:" . PHP_EOL;
  
  foreach ($response['hits']['hits'] as $hit) {
    echo "ID:" . $hit['_id'] . ",Name:" . $hit['_source']['name'] . ",Age:" . $hit['_source']['age'] . ",Email:" . $hit['_source']['email'] . PHP_EOL;
  }
?>
ログイン後にコピー
上記の例では、検索されたユーザー情報が表示されます。

結論:

この記事では、PHP 環境で Elasticsearch をリレーショナル データベースと統合する方法を紹介し、具体的なコード例を示します。読者の皆様がこの記事のガイダンスを通じて 2 つのシームレスな統合を成功裏に実現し、それによって Elasticsearch の強力な機能とパフォーマンスの利点を最大限に活用し、データの保存と処理の効率と品質を向上できることを願っています。

以上がPHP Elasticsearch とリレーショナル データベースの統合実践ガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

CakePHP のロギング CakePHP のロギング Sep 10, 2024 pm 05:26 PM

CakePHP へのログインは非常に簡単な作業です。使用する関数は 1 つだけです。 cronjob などのバックグラウンド プロセスのエラー、例外、ユーザー アクティビティ、ユーザーが実行したアクションをログに記録できます。 CakePHP でのデータのログ記録は簡単です。 log()関数が提供されています

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP クイックガイド CakePHP クイックガイド Sep 10, 2024 pm 05:27 PM

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。

See all articles