PHP에서 데이터베이스 간 쿼리를 실행하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-11 14:48:03
원래의
190명이 탐색했습니다.

How to Execute Cross Database Queries in PHP?

PHP의 교차 데이터베이스 쿼리: 장벽 깨기

이전 에피소드에서는 MySQL에서 교차 데이터베이스 쿼리 구성이 가능해졌습니다. 그러나 이 지식을 PHP로 변환하는 것은 mysql_select_db의 제한으로 인해 장애물이 되었습니다.

옵션 및 제한 사항

PHP에서 사용할 수 있는 옵션은 다음과 같습니다.

  • mysql_select_db 사용: 세션당 하나의 데이터베이스로 사용을 제한합니다. 데이터베이스 간 참조를 사용하려는 시도가 실패합니다.
  • mysql_select_db를 피하십시오: 모든 쿼리에 대해 데이터베이스를 지정해야 하며 이는 지루하고 비실용적입니다.

솔루션

이러한 제한을 극복하고 PHP에서 데이터베이스 간 쿼리를 수행하려면 다음 방법을 활용할 수 있습니다.

$db = mysql_connect($hots, $user, $password);
mysql_select_db('my_most_used_db', $db);

$q = mysql_query("
    SELECT *
    FROM   table_on_default_db a, `another_db`.`table_on_another_db` b
    WHERE  a.id = b.fk_id
");
로그인 후 복사

전제 조건

이 접근 방식을 사용하려면 두 데이터베이스가 모두 동일한 호스트에 있어야 합니다. 서로 다른 호스트에 있는 경우 직접 조인이 불가능합니다. 이 경우 두 가지 별도의 쿼리를 실행할 수 있습니다.

$db1 = mysql_connect($host1, $user1, $password1);
$db2 = mysql_connect($host2, $user2, $password2);

$q1 = mysql_query("
    SELECT id
    FROM   table
    WHERE  [..your criteria for db1 here..]
", $db1);
$tmp = array();
while($val = mysql_fetch_array($q1))
    $tmp[] = $val['id'];

$q2 = mysql_query("
    SELECT *
    FROM   table2
    WHERE  fk_id in (".implode(', ', $tmp).")
", $db2);
로그인 후 복사

이 방법을 활용하면 PHP에서 데이터베이스 간 쿼리를 손쉽게 수행하여 데이터베이스 상호 작용 기능을 확장할 수 있습니다.

위 내용은 PHP에서 데이터베이스 간 쿼리를 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿