


Présentation de la manière de compléter une requête conjointe de table de deux bases de données de serveur différentes en PHP
Apr 06, 2023 am 09:14 AMPour les développeurs utilisant PHP, un scénario courant est la nécessité d'interroger conjointement les données des bases de données de deux serveurs différents. Ce scénario peut être dû aux besoins de l'entreprise ou au fait que les données sont distribuées sur différents serveurs. Cet article expliquera comment réaliser cette opération de requête de fédération de données en PHP.
1. Déterminez les données requises pour la requête
Avant de commencer à écrire du code, nous devons déterminer les données que nous souhaitons interroger. Supposons que nous ayons deux services de base de données, nommés A et B. Nous devons interroger conjointement les informations client de ces deux bases de données, notamment l'identifiant client, le nom, l'âge et le sexe. Les deux bases de données A et B ont des tables clients, qui sont respectivement customers_a
et customers_b
. Ces tableaux incluent des informations de base sur les clients. customers_a
和customers_b
。这些表都包括客户的基本信息。
我们的查询目标是获取customers_a
和customers_b
中所有客户的信息,因此我们需要在两个表上执行JOIN操作。
2. 连接两个数据库
使用PHP连接两个数据库很容易。下面是连接A数据库的代码示例:
<?php $host = 'localhost'; $username = 'db_user'; $password = 'db_password'; $dbname = 'database_a'; $db_a = new mysqli($host, $username, $password, $dbname); if ($db_a->connect_error) { die('Connect Error (' . $db_a->connect_errno . ') ' . $db_a->connect_error); }
同样地,我们可以连接B数据库:
<?php $host = 'localhost'; $username = 'db_user'; $password = 'db_password'; $dbname = 'database_b'; $db_b = new mysqli($host, $username, $password, $dbname); if ($db_b->connect_error) { die('Connect Error (' . $db_b->connect_errno . ') ' . $db_b->connect_error); }
现在我们已经成功连接到了两个不同的数据库。
3. 执行联合查询操作
接下来,我们需要在两个数据库上执行JOIN操作,获取我们需要的数据。为了保证代码的可读性和易维护性,我们将查询操作封装成一个函数。
<?php function get_customers($db_a, $db_b) { $sql = "SELECT id, name, age, gender FROM customers_a UNION SELECT id, name, age, gender FROM customers_b"; $result = $db_a->query($sql); if (!$result) { die('Query Error: ' . $db_a->error); } $rows = array(); while ($row = $result->fetch_assoc()) { $rows[] = $row; } $result->free(); return $rows; }
在这个函数中,我们使用了UNION操作,将customers_a
和customers_b
中的数据合并在一起。执行完查询之后,我们将结果集中的记录放到一个数组中,并返回该数组。
4. 调用查询函数
现在我们已经完成了所有的代码编写工作。我们可以在代码中调用get_customers
customers_a
et customers_b
, nous devons donc effectuer des opérations JOIN sur les deux tables. 2. Connectez deux bases de donnéesIl est facile de connecter deux bases de données en utilisant PHP. Voici un exemple de code pour se connecter à la base de données A : <?php
$rows = get_customers($db_a, $db_b);
foreach ($rows as $row) {
echo $row['id'] . ' ' . $row['name'] . ' ' . $row['age'] . ' ' . $row['gender'] . '<br>';
}
Copier après la connexion
De même, nous pouvons nous connecter à la base de données B :
<?php $rows = get_customers($db_a, $db_b); foreach ($rows as $row) { echo $row['id'] . ' ' . $row['name'] . ' ' . $row['age'] . ' ' . $row['gender'] . '<br>'; }
<?php $host_a = 'localhost'; $username_a = 'db_user'; $password_a = 'db_password'; $dbname_a = 'database_a'; $host_b = 'localhost'; $username_b = 'db_user'; $password_b = 'db_password'; $dbname_b = 'database_b'; $db_a = new mysqli($host_a, $username_a, $password_a, $dbname_a); if ($db_a->connect_error) { die('Connect Error (' . $db_a->connect_errno . ') ' . $db_a->connect_error); } $db_b = new mysqli($host_b, $username_b, $password_b, $dbname_b); if ($db_b->connect_error) { die('Connect Error (' . $db_b->connect_errno . ') ' . $db_b->connect_error); } function get_customers($db_a, $db_b) { $sql = "SELECT id, name, age, gender FROM customers_a UNION SELECT id, name, age, gender FROM customers_b"; $result = $db_a->query($sql); if (!$result) { die('Query Error: ' . $db_a->error); } $rows = array(); while ($row = $result->fetch_assoc()) { $rows[] = $row; } $result->free(); return $rows; } $rows = get_customers($db_a, $db_b); foreach ($rows as $row) { echo $row['id'] . ' ' . $row['name'] . ' ' . $row['age'] . ' ' . $row['gender'] . '<br>'; } $db_a->close(); $db_b->close(); ?>
customers_a
et customers_b
ensemble. Après avoir exécuté la requête, nous plaçons les enregistrements du jeu de résultats dans un tableau et renvoyons le tableau. 🎜🎜4. Appelez la fonction de requête🎜🎜Maintenant, nous avons terminé tout le travail de codage. Nous pouvons appeler la fonction get_customers
dans le code pour obtenir les informations client interrogées conjointement dans les deux bases de données A et B. 🎜rrreee🎜5. Exemple de code complet🎜🎜Ce qui suit est l'exemple de code complet :🎜rrreee🎜Résumé🎜🎜En PHP, connecter deux bases de données différentes et effectuer des opérations de requête conjointes est un scénario très courant. Cet article décrit comment connecter deux services de base de données différents en PHP et utiliser l'opération UNION pour effectuer la tâche de requête conjointe. Grâce à cet article, nous espérons que les lecteurs pourront mieux comprendre comment utiliser plusieurs services de bases de données en PHP. 🎜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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

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)

Sujets chauds

Quelles sont les meilleures pratiques pour la déduplication des tableaux PHP

Quelles sont les dernières normes de codage PHP et les meilleures pratiques?

La déduplication PHP Array peut-elle profiter de l'unicité du nom clé?

Comment puis-je travailler avec les extensions de PHP et PECL?

Comment implémenter les files d'attente de messages (Rabbitmq, Redis) dans PHP?

La déduplication du tableau PHP doit-elle être prise en compte pour les pertes de performance?

Quelles sont les techniques d'optimisation pour la déduplication des tableaux PHP

Comment utiliser la réflexion pour analyser et manipuler le code PHP?
