>백엔드 개발 >PHP 튜토리얼 >PHP에서 여러 MySQL 쿼리를 독립적으로 실행하려면 어떻게 해야 합니까?

PHP에서 여러 MySQL 쿼리를 독립적으로 실행하려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-12-03 06:10:10234검색

How Can I Execute Multiple MySQL Queries Independently in PHP?

PHP를 사용하여 여러 MySQL 쿼리를 하나로 실행

문제:

두 개의 별도 MySQL 쿼리를 실행하고 처리해야 합니다. 그 결과는 PHP에서 독립적으로 나타납니다. 쿼리는 다음과 같습니다.

SELECT SQL_CALC_FOUND_ROWS Id, Name FROM my_table WHERE Name LIKE '%prashant%' LIMIT 0, 10;
SELECT FOUND_ROWS();

답변:

PHP의 표준 mysql_ 확장을 사용하면 여러 쿼리를 단일 트랜잭션으로 실행할 수 없습니다. 그러나 다음 단계에 따라 원하는 결과를 얻을 수 있습니다.

  1. 첫 번째 쿼리 실행:
$query1 = "SELECT SQL_CALC_FOUND_ROWS Id, Name FROM my_table WHERE Name LIKE '%prashant%' LIMIT 0, 10;";
$result1 = mysql_query($query1);
  1. 두 번째 실행 쿼리:
$query2 = "SELECT FOUND_ROWS();";
$result2 = mysql_query($query2);
  1. 첫 번째 쿼리 결과 가져오기:
$rows1 = mysql_fetch_all($result1, MYSQL_ASSOC);
  1. 두 번째 결과 가져오기 쿼리:
$totalRows = mysql_fetch_row($result2)[0];

다음 단계에 따라 두 쿼리를 독립적으로 실행하고 결과를 별도로 처리할 수 있습니다. 이 접근 방식은 단일 트랜잭션으로 실행하는 것만큼 효율적이지는 않지만 mysql_ 확장을 사용하여 원하는 결과를 얻을 수 있는 유일한 방법입니다.

대체 솔루션(사용되지 않음):

업데이트: 이전에는 mysql_connect()를 사용하여 하나의 명령문에서 여러 쿼리를 실행하는 것이 가능하다고 생각되었습니다. 플래그와 함께 기능합니다. 그러나 이 방법은 더 이상 사용되지 않으므로 사용해서는 안 됩니다.

최신 솔루션:

최신 PHP 애플리케이션의 경우 PDO(PHP 데이터 Objects) 데이터베이스 상호 작용을 위한 확장입니다. PDO는 SQL 쿼리를 실행하고 결과를 검색하는 보다 객체 지향적이고 일관된 방법을 제공합니다. PDO를 사용하면 다음과 같이 두 가지 쿼리를 실행할 수 있습니다.

$pdo = new PDO('mysql:host=localhost;dbname=your_database', 'username', 'password');
$stmt1 = $pdo->prepare($query1);
$stmt2 = $pdo->prepare($query2);

$stmt1->execute();
$rows1 = $stmt1->fetchAll(PDO::FETCH_ASSOC);

$stmt2->execute();
$totalRows = $stmt2->fetchColumn();

이 솔루션은 이전 mysql_ 확장보다 더 효율적이고 사용하기 쉽습니다.

위 내용은 PHP에서 여러 MySQL 쿼리를 독립적으로 실행하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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