개발자 Q&A

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

2025.04.03 00:47

SQLSRV_PREPARE 함수 사용 중 오류 발생

목록
  • 함수형광신도 2일 전 2025.04.03 00:47
  • 2
    1
제가 사용 중인 PHP 코드에서 SQLSRV_PREPARE 함수를 사용하여 SQL 쿼리를 실행하려고 하는데, 다음과 같은 오류가 발생하고 있어요.

php

$server = 'localhost';

$database = 'mydb';

$username = 'myuser';

$password = 'mypassword';



$conn = sqlsrv_connect($server, array(

    "Database"=>$database,

    "UID"=>$username,

    "PWD"=>$password

));



if ($conn === false) {

    die(print_r(sqlsrv_errors(), true));

}



$stmt = sqlsrv_prepare($conn, "SELECT * FROM mytable WHERE id = ?");

if (!$stmt) {

    die(print_r(sqlsrv_errors(), true));

}



위 코드에서 SQLSRV_PREPARE 함수를 사용하여 쿼리를 실행하려고 하는데, 쿼리에서 '?' 를 사용하여 변수를 대체하려는 시도를 하려고 하는데, 오류가 발생하고 있어요. 오류의 원인은 무엇이며, 어떻게 해결할 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    SQLSRV_PREPARE 함수를 사용하여 쿼리를 실행할 때, '?'를 사용하여 변수를 대체하려는 시도가 오류를 발생시키는 이유는 '?'를 사용하여 변수를 대체하려면, sqlsrv_prepare() 함수의 4번째 인자로 변수의 타입을 지정해야 한다는 것입니다.

    예를 들어, 쿼리에서 'id'라는 변수를 대체하려면, sqlsrv_prepare() 함수의 4번째 인자로 'int'를 지정해야 합니다.

    오류를 해결하기 위해서는, sqlsrv_prepare() 함수의 4번째 인자로 변수의 타입을 지정해야 합니다.

    #hostingforum.kr
    php
    
    $stmt = sqlsrv_prepare($conn, "SELECT * FROM mytable WHERE id = ?", array('int'));
    
    


    또한, 쿼리에서 '?'를 사용하여 변수를 대체하려면, sqlsrv_execute() 함수를 사용하여 쿼리를 실행해야 합니다.

    #hostingforum.kr
    php
    
    if (sqlsrv_execute($stmt)) {
    
        // 쿼리 실행 성공
    
    } else {
    
        // 쿼리 실행 실패
    
    }
    
    


    위 코드를 수정하여 오류를 해결할 수 있습니다.

    2025-04-03 00:48

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

검색

게시물 검색