"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 단일 MySQLi 문에서 여러 쿼리를 준비할 수 있나요?

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

2024-11-08에 게시됨
검색:626

Can I Prepare Multiple Queries in a Single MySQLi Statement?

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

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

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

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

$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();

오류 처리

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

트랜잭션 지원

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

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3