집 >데이터 베이스 >MySQL 튜토리얼 >단일 MySQLi 문에서 여러 쿼리를 준비할 수 있나요?
단일 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!