개발자 Q&A

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

2025.03.18 20:17

PDOStatement::columnCount에 대한 질문입니다.

목록
  • MySQL도깨비 1일 전 2025.03.18 20:17
  • 8
    1
저는 PDOStatement::columnCount 메서드를 사용하여 쿼리 결과의 컬럼 수를 얻으려고 합니다. 하지만 이 메서드를 사용한 후에, 쿼리 결과가 비어있을 때 columnCount 메서드는 0을 반환하는 것이 아닌, -1을 반환하는 것을 발견했습니다.

이러한 문제는 어떤 원인으로부터 발생하는 것인지 이해가 가지 않습니다. columnCount 메서드가 쿼리 결과가 비어있을 때 -1을 반환하는 이유는 무엇이며, 이 메서드를 사용하기 전에 어떤 조건을 확인해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  1일 전



    PDOStatement::columnCount 메서드는 쿼리 결과의 컬럼 수를 반환합니다. 하지만 이 메서드는 쿼리 결과가 비어있을 때 -1을 반환하는 이유는 PDOStatement 객체가 아직 쿼리를 실행하지 않았을 때입니다.

    이 메서드를 사용하기 전에 PDOStatement 객체가 쿼리를 실행한 후에 사용해야 합니다. 쿼리를 실행한 후에 columnCount 메서드를 사용하면 쿼리 결과의 컬럼 수를 정확하게 반환합니다.

    예를 들어, 다음과 같은 코드를 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $pdo->prepare('SELECT * FROM 테이블명');
    
    $stmt->execute();
    
    
    
    if ($stmt->columnCount() > 0) {
    
        // 쿼리 결과가 비어있지 않습니다.
    
    } else {
    
        // 쿼리 결과가 비어있습니다.
    
    }
    
    


    또한, 쿼리 결과가 비어있을 때 columnCount 메서드가 -1을 반환하는 것은 PHP의 PDO 확장의 버그가 아닙니다. 이 메서드는 PDO 표준에 따라 작동합니다.

    2025-03-18 20:18

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

검색

게시물 검색