개발자 Q&A

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

2025.03.16 23:12

pg_send_query_params 사용 시 오류 발생 원인

  • Swift매니아 5시간 전 2025.03.16 23:12 새글
  • 4
    1
저는 PostgreSQL에서 pg_send_query_params 함수를 사용하여 동적 쿼리를 실행하려합니다.
하지만, query string에 문자열이 포함되어 있을 때 오류가 발생하는 것을 경험했습니다.
이러한 오류는 어떻게 해결해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  5시간 전



    pg_send_query_params 함수를 사용할 때 query string에 문자열이 포함되어 오류가 발생하는 원인은 주로 문자열이 따옴표로 감싸여 있기 때문입니다.

    따라서, 문자열을 따옴표로 감싸지 않도록 하거나, 따옴표를 이스케이프 처리하는 방법을 사용하면 오류를 해결할 수 있습니다.

    예를 들어, query string에 포함된 문자열을 이스케이프 처리하는 방법은 다음과 같습니다.

    #hostingforum.kr
    sql
    
    query := "SELECT * FROM 테이블 WHERE 이름 = '" + string(이름) + "'";
    
    


    위의 방법은 문자열을 이스케이프 처리하는 방법입니다. 하지만, PostgreSQL에서 제공하는 quote_literal 함수를 사용하는 방법도 있습니다.

    #hostingforum.kr
    sql
    
    query := "SELECT * FROM 테이블 WHERE 이름 = " + quote_literal(string(이름)) + "";
    
    


    위의 방법은 PostgreSQL에서 제공하는 quote_literal 함수를 사용하는 방법입니다. 이 함수는 문자열을 이스케이프 처리하여 따옴표로 감싸줍니다.

    또한, PostgreSQL 9.4 이상부터는 quote_literal 함수 대신 quote_ident 함수를 사용할 수 있습니다. 이 함수는 식별자(예: 테이블 이름, 컬럼 이름)를 이스케이프 처리하여 따옴표로 감싸줍니다.

    #hostingforum.kr
    sql
    
    query := "SELECT * FROM " + quote_ident("테이블") + " WHERE 이름 = " + quote_literal(string(이름)) + "";
    
    


    위의 방법은 식별자와 문자열을 이스케이프 처리하여 따옴표로 감싸줍니다.

    2025-03-16 23:13

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

검색

게시물 검색