Pour 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.
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操作。
使用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); }
现在我们已经成功连接到了两个不同的数据库。
接下来,我们需要在两个数据库上执行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
中的数据合并在一起。执行完查询之后,我们将结果集中的记录放到一个数组中,并返回该数组。
现在我们已经完成了所有的代码编写工作。我们可以在代码中调用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>'; }
<?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!