집 >데이터 베이스 >MySQL 튜토리얼 >PHP에서 데이터베이스 간 쿼리를 실행하는 방법은 무엇입니까?
PHP의 교차 데이터베이스 쿼리: 장벽 깨기
이전 에피소드에서는 MySQL에서 교차 데이터베이스 쿼리 구성이 가능해졌습니다. 그러나 이 지식을 PHP로 변환하는 것은 mysql_select_db의 제한으로 인해 장애물이 되었습니다.
옵션 및 제한 사항
PHP에서 사용할 수 있는 옵션은 다음과 같습니다.
솔루션
이러한 제한을 극복하고 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!