개발자 Q&A

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

2025.06.18 19:27

pg_prepare 함수를 사용하여 SQL 쿼리 전달시 오류 발생

목록
  • 노드장인 오래 전 2025.06.18 19:27 인기
  • 297
    1
저는 pg_prepare 함수를 사용하여 SQL 쿼리 전달을 시도하고 있습니다. 하지만, SQL 쿼리 중 WHERE 조건에 변수를 사용하여 전달 시 오류가 발생하고 있습니다. 예를 들어, 다음과 같이 SQL 쿼리를 전달하려고 합니다.

sql

PREPARE my_query(text) AS

SELECT * FROM users WHERE name = $1;



그리고, 다음과 같이 SQL 쿼리를 실행하려고 합니다.

sql

EXECUTE my_query('john');



하지만, SQL 쿼리 중 WHERE 조건에 변수를 사용하여 전달 시 오류가 발생하고 있습니다. 오류 메시지는 다음과 같습니다.

sql

ERROR:  syntax error at or near "$1"

LINE 1: SELECT * FROM users WHERE name = $1;



저는 pg_prepare 함수를 사용하여 SQL 쿼리 전달 시 오류가 발생하는 이유를 알고 싶습니다. 또한, 오류를 해결하는 방법을 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  오래 전



    pg_prepare 함수를 사용하여 SQL 쿼리 전달 시 오류가 발생하는 이유는, SQL 쿼리 내에서 변수를 직접 사용하는 것이 아닌, $1, $2, $3 등과 같은 placeholder를 사용해야 한다는 것입니다.

    WHERE 조건에 변수를 사용하여 전달 시 오류가 발생하는 이유는, SQL 쿼리 내에서 변수를 직접 사용하는 것이 아닌, placeholder를 사용해야 한다는 것입니다.

    오류를 해결하는 방법은, SQL 쿼리 내에서 placeholder를 사용하여 변수를 전달하는 것입니다.

    예를 들어, 다음과 같이 SQL 쿼리를 전달하려고 합니다.

    sql
    
    PREPARE my_query(text) AS
    
    SELECT * FROM users WHERE name = $1;
    
    


    그리고, 다음과 같이 SQL 쿼리를 실행하려고 합니다.

    sql
    
    EXECUTE my_query('john');
    
    


    이 경우, 오류가 발생하지 않습니다.

    또한, pg_prepare 함수를 사용하여 SQL 쿼리 전달 시 오류를 해결하는 방법은, SQL 쿼리 내에서 placeholder를 사용하여 변수를 전달하는 것입니다.

    예를 들어, 다음과 같이 SQL 쿼리를 전달하려고 합니다.

    sql
    
    PREPARE my_query(text) AS
    
    SELECT * FROM users WHERE name = $1;
    
    


    그리고, 다음과 같이 SQL 쿼리를 실행하려고 합니다.

    sql
    
    EXECUTE my_query('john');
    
    


    이 경우, 오류가 발생하지 않습니다.

    pg_prepare 함수를 사용하여 SQL 쿼리 전달 시 오류를 해결하는 방법은, SQL 쿼리 내에서 placeholder를 사용하여 변수를 전달하는 것입니다.

    2025-06-18 19:28

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

검색

게시물 검색