>데이터 베이스 >MySQL 튜토리얼 >단일 MySQLi 문에서 여러 쿼리를 준비할 수 있나요?

단일 MySQLi 문에서 여러 쿼리를 준비할 수 있나요?

Linda Hamilton
Linda Hamilton원래의
2024-11-02 08:55:29968검색

Can I Prepare Multiple Queries in a Single MySQLi Statement?

단일 MySQLi 문에서 여러 쿼리 준비

단일 MySQLi 문에서 여러 쿼리를 준비하는 것은 불가능합니다. 각 mysqli_prepare() 호출은 단일 쿼리만 준비할 수 있습니다.

여러 쿼리 실행을 위한 대체 접근 방식

한 번에 여러 쿼리를 실행해야 하는 경우 다음을 생성할 수 있습니다. 그리고 각 쿼리에 대해 별도의 mysqli_prepare() 문을 실행합니다.

<code class="php">$stmtUser = $sql->prepare("INSERT INTO user (id_user, username, pw, email) VALUES (?,?,?,?)");
$stmtProc = $sql->prepare("INSERT INTO process (id_user, idp) VALUES (?,?);");

$stmtUser->bind_param("ssss", $id, $username, $pw, $email);
$stmtProc->bind_param("ss", $id, $idp);

$stmtUser->execute();
$stmtProc->execute();

$stmtUser->close();
$stmtProc->close();</code>

오류 처리

"비객체에서 멤버 함수 호출" 오류는 일반적으로 prepare()가 실패할 때 발생합니다. 이는 대개 후속 코드가 아닌 준비된 문 자체의 오류로 인해 발생합니다.

트랜잭션 지원

여러 쿼리가 함께 실행되는지 확인하려는 경우 또는 전혀 아닙니다. MySQLi는 트랜잭션을 지원합니다. mysqli_begin_transaction() 및 mysqli_commit() 함수를 사용하여 트랜잭션 경계를 제어할 수 있습니다.

위 내용은 단일 MySQLi 문에서 여러 쿼리를 준비할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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