개발자 Q&A

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

2025.08.03 21:41

Session::sql 오류 해결 방법

목록
  • Android개발광 3시간 전 2025.08.03 21:41 새글
  • 1
    1
제가 현재 프로젝트에서 Session::sql을 사용 중인데,
다음과 같은 오류가 발생하고 있습니다.

php

$session = new Session();

$session->sql('SELECT * FROM users WHERE id = ?', [1]);



위 코드를 실행하면 오류가 발생하는데,
에러 메시지는 다음과 같습니다.

`Session::sql() expects parameter 1 to be string, array given`

제가 이해한 바로는 Session::sql() 메소드는 SQL 쿼리를 실행할 때,
물음표 (?)를 대신할 값을 배열로 전달해야 한다고 합니다.
그러나 제 경우에는 배열을 전달했는데도 오류가 발생하는 것 같습니다.

제가 잘못 이해한 부분이 있는지, 혹은 제 코드에 오류가 있는지 알려주시겠어요?

또한, 만약에 제 코드가 정상적으로 작동하지 않는다면,
어떻게 수정해야 하는지 알려주시겠어요?

제가 감사합니다.

    댓글목록

    profile_image
    나우호스팅  3시간 전



    Session::sql() 메소드는 SQL 쿼리에서 물음표 (?)를 대신할 값을 배열로 전달하는 방식으로 작동합니다. 하지만, 이 메소드는 SQL 쿼리 자체를 문자열로 전달해야 합니다.

    예를 들어, 다음과 같이 SQL 쿼리와 값을 전달해야 합니다.

    #hostingforum.kr
    php
    
    $session = new Session();
    
    $session->sql('SELECT * FROM users WHERE id = ?', [1]);
    
    


    위 코드에서 'SELECT * FROM users WHERE id = ?'는 SQL 쿼리 문자열입니다. [1]은 쿼리에서 물음표 (?)를 대신할 값입니다.

    따라서, 제 코드에서 오류는 SQL 쿼리 문자열이 아닌 배열이 전달된 때문입니다.

    위 코드를 다음과 같이 수정하면 정상적으로 작동할 것입니다.

    #hostingforum.kr
    php
    
    $session = new Session();
    
    $session->sql('SELECT * FROM users WHERE id = ?', [1]);
    
    

    2025-08-03 21:42

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

검색

게시물 검색