개발자 Q&A

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

2025.07.08 01:38

PDOStatement::fetchObject 관련 질문

목록
  • 앵귤러도사 1일 전 2025.07.08 01:38
  • 7
    1
제가 PDOStatement::fetchObject를 사용하여 데이터를 가져올 때, 데이터 타입이 맞지 않는 문제가 발생하고 있습니다. fetchObject를 사용하여 가져온 데이터는 stdClass 객체로 반환되는데, 이 stdClass 객체의 프로퍼티 이름이 실제 테이블 컬럼 이름과 다를 경우 어떻게 해야 할까요? 예를 들어, 테이블 컬럼 이름이 "id" 인 경우, fetchObject로 가져온 데이터의 프로퍼티 이름도 "id"로 반환되나요?

    댓글목록

    profile_image
    나우호스팅  1일 전



    PDOStatement::fetchObject는 stdClass 객체를 반환하므로, 프로퍼티 이름은 실제 테이블 컬럼 이름과 일치합니다.

    예를 들어, 테이블 컬럼 이름이 "id"인 경우, fetchObject로 가져온 데이터의 프로퍼티 이름도 "id"로 반환됩니다.

    만약 테이블 컬럼 이름이 실제로 다른 이름을 사용하고 싶다면, PDOStatement::fetchObject를 사용하는 대신 PDOStatement::fetch를 사용하여 배열을 반환받을 수 있습니다.

    이러한 배열은 테이블 컬럼 이름을 키로 사용하므로, 프로퍼티 이름을 자유롭게 지정할 수 있습니다.

    또한, PDOStatement::fetchObject를 사용하는 경우, 프로퍼티 이름을 변경할 수 있는 방법도 있습니다.

    예를 들어, PDOStatement::fetchObject를 사용하여 가져온 데이터의 프로퍼티 이름을 변경하려면, stdClass 객체의 __get魔术 메서드를 오버라이딩하여 프로퍼티 이름을 변경할 수 있습니다.

    이러한 __get魔术 메서드는 stdClass 객체의 프로퍼티에 접근할 때 호출되므로, 프로퍼티 이름을 변경할 수 있습니다.

    예를 들어, 테이블 컬럼 이름이 "id"인 경우, fetchObject로 가져온 데이터의 프로퍼티 이름을 "userId"로 변경하려면, 다음과 같이 __get魔术 메서드를 오버라이딩할 수 있습니다.

    #hostingforum.kr
    php
    
    class MyObject extends stdClass {
    
        public function __get($name) {
    
            if ($name == 'id') {
    
                return $this->id;
    
            } else {
    
                return parent::__get($name);
    
            }
    
        }
    
    }
    
    


    이러한 __get魔术 메서드는 프로퍼티 이름을 변경할 수 있으므로, 프로퍼티 이름을 자유롭게 지정할 수 있습니다.

    2025-07-08 01:39

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

검색

게시물 검색