> 백엔드 개발 > PHP 튜토리얼 > PHP에서 여러 MySQLi 쿼리를 동시에 실행하려면 어떻게 해야 합니까?

PHP에서 여러 MySQLi 쿼리를 동시에 실행하려면 어떻게 해야 합니까?

Linda Hamilton
풀어 주다: 2024-12-08 02:41:14
원래의
405명이 탐색했습니다.

How Can I Execute Multiple MySQLi Queries Simultaneously in PHP?

다중 mysqli 쿼리: mysqli_multi_query() 이해

MySQLi를 사용하면 단일 요청으로 여러 쿼리를 실행하는 것이 간단하지 않습니다. 별도의 mysqli_query() 호출을 실행하려고 시도하면 첫 번째 쿼리만 실행됩니다. 이러한 제한을 극복하기 위해 mysqli_multi_query()는 한 번에 여러 SQL 문을 실행할 수 있는 솔루션을 제공합니다.

구현 예:

다음 시나리오를 고려하세요.

mysqli_query($dblink, "INSERT INTO images ...");
mysqli_query($dblink, "INSERT INTO images_history ...");
로그인 후 복사

두 쿼리를 동시에 실행하려면 다음을 사용하세요. mysqli_multi_query():

$mysqli = new mysqli(...);
$query = "INSERT INTO images ...";
$query .= "INSERT INTO images_history ...";

$result = mysqli_multi_query($mysqli, $query);

if ($result) {
    while (mysqli_more_results($mysqli) && mysqli_next_result($mysqli)) {
        if (($result = mysqli_store_result($mysqli)) === false && mysqli_error($mysqli) != '') {
            echo "Query failed: " . mysqli_error($mysqli);
        }
    }
} else {
    echo "First query failed..." . mysqli_error($mysqli);
}
로그인 후 복사

주요 고려 사항:

  • mysqli_multi_query()에는 세미콜론(;)으로 구분된 모든 쿼리가 포함된 문자열이 필요합니다.
  • mysqli_store_result()를 사용하여 결과를 검색해야 합니다. 각 쿼리. INSERT 쿼리는 결과 세트를 반환하지 않으므로 mysqli_error()에서 빈 문자열을 확인하여 삽입이 성공했는지 확인하세요.
  • 이 접근 방식은 여러 mysqli_query() 호출을 실행할 때 발생하는 SQL 주입을 방지하므로 안전합니다.

추가 리소스:

  • [mysqli_multi_query](https://www.php.net/manual/en/mysqli.multi-query.php)
  • [mysqli_more_results]( https://www.php.net/manual/en/mysqli.more-results .php)
  • [mysqli_next_result](https://www.php.net/manual/en/mysqli.next-result.php)
  • [mysqli_store_result](https://www .php.net/manual/en/mysqli.store-result.php)

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

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