개발자 Q&A

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

2025.04.30 17:49

PDOStatement::bindParam 메소드 사용 중 문제 발생

목록
  • Swift매니아 7시간 전 2025.04.30 17:49 새글
  • 4
    1
제가 지금까지 공부한 내용을 토대로 PDOStatement::bindParam 메소드를 사용하여 변수를 바인딩 한 후에, 변수의 값을 변경하고 싶습니다. 하지만, PDOStatement::bindParam 메소드의 변수를 변경하면, SQL 쿼리에서 사용되는 변수의 값도 함께 변경이 되는 것 같습니다.

이러한 경우 SQL 쿼리에서 사용되는 변수의 값은 변경되지 않도록 하기 위한 방법이 무엇인지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  7시간 전

    PDOStatement::bindParam 메소드는 SQL 쿼리에서 사용되는 변수의 값을 변경하지 않도록 하기 위해서는 PDOStatement::bindParam 메소드 대신 PDOStatement::bindValue 메소드를 사용하면 됩니다.

    PDOStatement::bindValue 메소드는 변수의 값을 변경하더라도 SQL 쿼리에서 사용되는 변수의 값은 변경되지 않습니다.

    예를 들어, 다음과 같이 코드를 작성할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $pdo->prepare("SELECT * FROM 테이블명 WHERE 이름 = :name");
    
    $stmt->bindValue(":name", "이름");
    
    


    이러한 코드는 PDOStatement::bindParam 메소드 대신 PDOStatement::bindValue 메소드를 사용하였으며, 변수의 값을 변경하더라도 SQL 쿼리에서 사용되는 변수의 값은 변경되지 않습니다.

    또한, PDOStatement::bindValue 메소드는 PDOStatement::bindParam 메소드보다 성능이 더 좋습니다.

    하지만, PDOStatement::bindParam 메소드는 변수의 값이 변경되면 SQL 쿼리에서 사용되는 변수의 값도 함께 변경되므로, PDOStatement::bindParam 메소드는 변수의 값이 변경되지 않는 경우에만 사용할 수 있습니다.

    따라서, PDOStatement::bindParam 메소드는 변수의 값이 변경되지 않는 경우에만 사용하고, 변수의 값이 변경되면 PDOStatement::bindValue 메소드를 사용하는 것이 좋습니다.

    2025-04-30 17:50

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

검색

게시물 검색