개발자 Q&A

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

2025.06.13 01:51

mysqli_stmt::prepare 함수 사용 시 오류 발생

목록
  • 함수형광신도 오래 전 2025.06.13 01:51
  • 96
    1
저는 현재 PHP에서 MySQL 연동을 위해 mysqli_stmt::prepare 함수를 사용 중인데, 오류가 발생하고 있습니다. prepare 함수를 사용하여 SQL문을 미리 컴파일하는 방법에 대해 궁금합니다.

prepare 함수를 사용한 SQL문은 다음과 같습니다.

php

$stmt = $mysqli->prepare("SELECT * FROM user WHERE name = ? AND age = ?");

$stmt->bind_param("si", $name, $age);



prepare 함수를 사용한 SQL문은 위와 같이 작성하였습니다. 하지만, bind_param 함수를 사용하여 파라미터를 바인딩할 때, ? 에서 ?를 두 개를 사용하여 바인딩을 하려는 것인데, 이 경우 오류가 발생합니다.

다른 방법으로 SQL문을 작성하면 오류가 발생하지 않는지 궁금합니다.

예를 들어, 다음과 같이 SQL문을 작성해도 오류가 발생하지 않나요?

php

$stmt = $mysqli->prepare("SELECT * FROM user WHERE name = ? AND age = ?");

$stmt->bind_param("si", $name, $age);



위와 같이 SQL문을 작성해도 오류가 발생하지 않는다면, prepare 함수를 사용하여 SQL문을 미리 컴파일하는 방법에 대해 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  오래 전



    mysqli_stmt::prepare 함수를 사용하여 SQL문을 미리 컴파일하는 방법에 대해 설명드리겠습니다.

    mysqli_stmt::prepare 함수는 SQL문을 미리 컴파일하여 성능을 향상시키는 함수입니다. 이 함수를 사용하여 SQL문을 미리 컴파일하면, SQL문을 실행할 때마다 컴파일하는 시간을節約할 수 있습니다.

    prepare 함수를 사용하여 SQL문을 미리 컴파일하는 방법은 다음과 같습니다.

    1. prepare 함수를 사용하여 SQL문을 미리 컴파일합니다.
    2. bind_param 함수를 사용하여 파라미터를 바인딩합니다.
    3. execute 함수를 사용하여 SQL문을 실행합니다.

    prepare 함수를 사용한 SQL문은 다음과 같습니다.

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM user WHERE name = ? AND age = ?");
    
    $stmt->bind_param("si", $name, $age);
    
    $stmt->execute();
    
    


    위와 같이 SQL문을 작성하면, prepare 함수를 사용하여 SQL문을 미리 컴파일하고, bind_param 함수를 사용하여 파라미터를 바인딩한 후, execute 함수를 사용하여 SQL문을 실행합니다.

    prepare 함수를 사용하여 SQL문을 미리 컴파일할 때, ? 에서 ?를 두 개를 사용하여 바인딩을 하려는 것은 오류가 발생할 수 있습니다. 이 경우, bind_param 함수의 두 번째 인자에서 ?를 두 개를 사용하여 바인딩할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM user WHERE name = ? AND age = ?");
    
    $stmt->bind_param("si", $name, $age);
    
    $stmt->execute();
    
    


    위와 같이 SQL문을 작성하면, prepare 함수를 사용하여 SQL문을 미리 컴파일하고, bind_param 함수를 사용하여 파라미터를 바인딩한 후, execute 함수를 사용하여 SQL문을 실행합니다.

    prepare 함수를 사용하여 SQL문을 미리 컴파일하는 방법에 대해 알려드렸습니다. 이 방법을 사용하면, SQL문을 실행할 때마다 컴파일하는 시간을節約할 수 있습니다.

    2025-06-13 01:52

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

검색

게시물 검색