개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.06.22 22:09

mysqli::multi_query 사용시 SQL 문이 하나 이상 실행되는지 확인하는 방법

목록
  • Scala마법사 오래 전 2025.06.22 22:09 인기
  • 208
    1
안녕하세요 선생님. MySQLi extension을 사용하여 SQL 문을 실행하는 동안 multi_query 함수를 사용하여 여러 개의 쿼리를 한번에 실행하는 방법을 배웠습니다. 그러나 이 함수를 사용했을 때, 여러 쿼리가 모두 실행되는지 확인하는 방법을 모르겠습니다.

예를 들어, 아래의 코드를 실행했을 때, 쿼리 1이 성공적으로 실행되었는지, 쿼리 2가 성공적으로 실행되었는지 확인하는 방법을 알려주시면 감사하겠습니다.

php

$mysqli = new mysqli("호스트", "유저명", "비밀번호", "데이터베이스명");



$query = "

    CREATE TABLE 테이블명 (

        열1 INT,

        열2 VARCHAR(255)

    );

    INSERT INTO 테이블명 (열1, 열2) VALUES (1, '값1');

";



$mysqli->multi_query($query);



이 코드를 실행했을 때, 쿼리 1이 성공적으로 실행되었는지를 확인하는 방법을 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  오래 전



    mysqli::multi_query 함수를 사용하여 여러 쿼리를 한번에 실행한 후, 쿼리들이 모두 성공적으로 실행되었는지 확인하는 방법은 다음과 같습니다.

    #hostingforum.kr
    php
    
    $mysqli = new mysqli("호스트", "유저명", "비밀번호", "데이터베이스명");
    
    
    
    $query = "
    
        CREATE TABLE 테이블명 (
    
            열1 INT,
    
            열2 VARCHAR(255)
    
        );
    
        INSERT INTO 테이블명 (열1, 열2) VALUES (1, '값1');
    
    ";
    
    
    
    $mysqli->multi_query($query);
    
    
    
    $mysqli->next_result();
    
    
    
    if ($result = $mysqli->store_result()) {
    
        while ($row = $result->fetch_row()) {
    
            // 쿼리 결과를 처리합니다.
    
        }
    
        $result->free();
    
    }
    
    
    
    // 에러가 발생한 쿼리를 확인합니다.
    
    if ($mysqli->errno) {
    
        echo "에러가 발생했습니다. 쿼리: $query, 에러 메시지: " . $mysqli->error;
    
    }
    
    


    위 코드에서 `$mysqli->next_result()` 함수를 사용하여 쿼리 결과를 처리하기 전에 다음 쿼리 결과를 얻을 수 있습니다. `$mysqli->store_result()` 함수를 사용하여 쿼리 결과를 저장한 후, `$result->fetch_row()` 함수를 사용하여 쿼리 결과를 처리합니다. 에러가 발생한 쿼리를 확인하기 위해 `$mysqli->errno` 변수를 사용합니다.

    2025-06-22 22:10

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 37,849건 / 14 페이지

검색

게시물 검색