>  기사  >  데이터 베이스  >  단일 mysqli 문에서 여러 쿼리를 실행할 수 있습니까?

단일 mysqli 문에서 여러 쿼리를 실행할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-29 03:57:29171검색

Can You Execute Multiple Queries in a Single mysqli Statement?

단일 mysqli 문에 여러 쿼리

여러 쿼리를 실행하는 단일 mysqli 문을 준비할 수 있나요?

질문:

여러 쿼리를 실행하는 단일 mysqli 문을 구성하는 것이 가능합니까? 예를 들면 다음과 같습니다.

<code class="php">mysqli->prepare("query1 ...1,2,3 param...; query2...4,5 param...");
or 
mysqli->prepare("insert into ...1,2,3 param...; insert into...4,5 param...");</code>

이러한 구성을 시도하면 "...의 객체가 아닌 멤버 함수에 대한 바인딩_param() 호출"이라는 오류가 발생합니다.

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

$stmt->bind_param("ssssss",$id, $username, $pw, $email, $id, $idp);

$stmt->execute();
$stmt->close(); </code>

답변:

준비된 문은 단일 MySQL 쿼리만 실행할 수 있습니다. 그러나 별도의 변수로 여러 명령문을 준비할 수 있습니다.

<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 (?,?);");</code>

이러한 명령문은 나중에 실행할 수 있습니다. 두 쿼리가 모두 성공적으로 실행되도록 해야 하는 경우 트랜잭션 사용을 고려하십시오.

"비객체에 대한 멤버 함수 호출" 오류는 일반적으로 prepare() 문의 실패를 의미하는 것이 아니라 준비() 문에 실패했음을 나타냅니다. 후속 코드에 문제가 있습니다.

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

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