>  기사  >  백엔드 개발  >  PHP에서 서로 다른 두 서버 데이터베이스의 테이블 결합 쿼리를 완료하는 방법을 소개합니다.

PHP에서 서로 다른 두 서버 데이터베이스의 테이블 결합 쿼리를 완료하는 방법을 소개합니다.

PHPz
PHPz원래의
2023-04-06 09:14:411095검색

PHP를 사용하는 개발자의 경우 일반적인 시나리오는 서로 다른 두 서버의 데이터베이스에서 데이터를 공동으로 쿼리해야 하는 것입니다. 이 시나리오는 비즈니스 요구로 인한 것일 수도 있고 데이터가 다른 서버에 분산되어 있기 때문일 수도 있습니다. 이 문서에서는 PHP에서 데이터 연합 쿼리 작업을 완료하는 방법을 소개합니다.

1. 쿼리에 필요한 데이터 결정

코드 작성을 시작하기 전에 쿼리할 데이터를 결정해야 합니다. A와 B라는 두 개의 데이터베이스 서비스가 있다고 가정합니다. 우리는 고객 ID, 이름, 나이, 성별을 포함하여 이 두 데이터베이스에서 고객 정보를 공동으로 쿼리해야 합니다. 데이터베이스 A와 B에는 각각 customers_acustomers_b인 고객 테이블이 있습니다. 이 테이블에는 고객에 대한 기본 정보가 포함되어 있습니다. customers_acustomers_b。这些表都包括客户的基本信息。

我们的查询目标是获取customers_acustomers_b中所有客户的信息,因此我们需要在两个表上执行JOIN操作。

2. 连接两个数据库

使用PHP连接两个数据库很容易。下面是连接A数据库的代码示例:

<?php
$host = &#39;localhost&#39;;
$username = &#39;db_user&#39;;
$password = &#39;db_password&#39;;
$dbname = &#39;database_a&#39;;

$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 = &#39;localhost&#39;;
$username = &#39;db_user&#39;;
$password = &#39;db_password&#39;;
$dbname = &#39;database_b&#39;;

$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_acustomers_b中的数据合并在一起。执行完查询之后,我们将结果集中的记录放到一个数组中,并返回该数组。

4. 调用查询函数

现在我们已经完成了所有的代码编写工作。我们可以在代码中调用get_customers

우리의 쿼리 목표는 customers_acustomers_b에 있는 모든 고객의 정보를 얻는 것이므로 두 테이블에 대해 JOIN 연산을 수행해야 합니다.

2. 두 개의 데이터베이스 연결

PHP를 사용하면 두 개의 데이터베이스를 쉽게 연결할 수 있습니다. 다음은 데이터베이스 A에 연결하는 코드 예제입니다.

<?php
$rows = get_customers($db_a, $db_b);
foreach ($rows as $row) {
    echo $row[&#39;id&#39;] . &#39; &#39; . $row[&#39;name&#39;] . &#39; &#39; . $row[&#39;age&#39;] . &#39; &#39; . $row[&#39;gender&#39;] . &#39;<br>';
}

마찬가지로 데이터베이스 B에 연결할 수 있습니다.

<?php
$host_a = &#39;localhost&#39;;
$username_a = &#39;db_user&#39;;
$password_a = &#39;db_password&#39;;
$dbname_a = &#39;database_a&#39;;

$host_b = &#39;localhost&#39;;
$username_b = &#39;db_user&#39;;
$password_b = &#39;db_password&#39;;
$dbname_b = &#39;database_b&#39;;

$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();
?>
이제 두 개의 서로 다른 데이터베이스에 성공적으로 연결되었습니다. 🎜🎜3. 공동 쿼리 작업 수행🎜🎜다음으로 필요한 데이터를 얻기 위해 두 데이터베이스에 대해 JOIN 작업을 수행해야 합니다. 코드의 가독성과 유지 관리성을 보장하기 위해 쿼리 작업을 함수로 캡슐화합니다. 🎜rrreee🎜이 함수에서는 UNION 연산을 사용하여 customers_acustomers_b의 데이터를 함께 병합합니다. 쿼리를 실행한 후 결과 집합의 레코드를 배열에 넣고 배열을 반환합니다. 🎜🎜4. 쿼리 함수 호출🎜🎜이제 모든 코딩 작업이 완료되었습니다. 코드에서 get_customers 함수를 호출하여 두 데이터베이스 A와 B에서 공동으로 쿼리한 고객 정보를 얻을 수 있습니다. 🎜rrreee🎜5. 전체 코드 예제🎜🎜다음은 전체 코드 예제입니다.🎜rrreee🎜요약🎜🎜PHP에서는 서로 다른 두 데이터베이스를 연결하고 통합 쿼리 작업을 수행하는 것이 매우 일반적인 시나리오입니다. 이 기사에서는 PHP에서 서로 다른 두 데이터베이스 서비스를 연결하고 UNION 작업을 사용하여 공동 쿼리 작업을 완료하는 방법을 소개합니다. 이 기사를 통해 독자들이 PHP에서 여러 데이터베이스 서비스를 사용하는 방법을 더 잘 이해할 수 있기를 바랍니다. 🎜

위 내용은 PHP에서 서로 다른 두 서버 데이터베이스의 테이블 결합 쿼리를 완료하는 방법을 소개합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.