개발자 Q&A

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

2025.07.29 06:32

SQLSRV_FETCH_OBJECT 사용법에 대한 도움을 부탁드립니다.

목록
  • 패턴마스터 14시간 전 2025.07.29 06:32 새글
  • 4
    1
제가 SQLSRV_FETCH_OBJECT를 사용하여 데이터베이스에서 데이터를 조회하고 객체로 반환할 때, 다음과 같은 문제가 발생합니다.

- 데이터베이스에서 데이터를 조회하는 SQL 문은 다음과 같습니다.
sql

SELECT * FROM 회원


- PHP에서 데이터베이스와 연결하여 데이터를 조회하는 코드는 다음과 같습니다.
php

$conn = sqlsrv_connect('localhost', array('Database' => 'mydb'));

$result = sqlsrv_query($conn, 'SELECT * FROM 회원');


- 데이터를 조회한 후, SQLSRV_FETCH_OBJECT를 사용하여 객체로 반환하는 코드는 다음과 같습니다.
php

while ($row = sqlsrv_fetch_object($result)) {

    echo $row->이름 . "n";

}


문제는, `$row->이름`과 같이 객체 프로퍼티를 사용할 때, `$row` 객체의 프로퍼티가 실제로 존재하는지 확인하는 방법이 없다는 것입니다. 예를 들어, `$row->이름`이 존재하지 않으면, PHP는 에러를 발생시키지 않고 NULL을 반환합니다.

이러한 문제를 해결할 방법이 있는지, 또는 SQLSRV_FETCH_OBJECT를 사용할 때 주의해야 할 점이 있는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  14시간 전



    SQLSRV_FETCH_OBJECT를 사용할 때, 객체의 프로퍼티가 실제로 존재하는지 확인하는 방법은 다음과 같습니다.

    1. `property_exists()` 함수를 사용하여 객체의 프로퍼티가 존재하는지 확인할 수 있습니다.

    #hostingforum.kr
    php
    
    if (property_exists($row, '이름')) {
    
        echo $row->이름 . "n";
    
    } else {
    
        echo "이름 프로퍼티가 존재하지 않습니다.n";
    
    }
    
    


    2. `isset()` 함수를 사용하여 객체의 프로퍼티가 존재하는지 확인할 수 있습니다. 하지만 `isset()` 함수는 프로퍼티가 존재하는지 확인하는 것이 아니라, 프로퍼티의 값이 NULL인지 확인합니다.

    #hostingforum.kr
    php
    
    if (isset($row->이름)) {
    
        echo $row->이름 . "n";
    
    } else {
    
        echo "이름 프로퍼티가 존재하지 않습니다.n";
    
    }
    
    


    3. `array_key_exists()` 함수를 사용하여 객체의 프로퍼티가 존재하는지 확인할 수 있습니다. 하지만 `array_key_exists()` 함수는 객체의 프로퍼티가 존재하는지 확인하는 것이 아니라, 객체가 배열인지를 확인합니다.

    #hostingforum.kr
    php
    
    if (array_key_exists('이름', get_object_vars($row))) {
    
        echo $row->이름 . "n";
    
    } else {
    
        echo "이름 프로퍼티가 존재하지 않습니다.n";
    
    }
    
    


    4. `get_object_vars()` 함수를 사용하여 객체의 프로퍼티를 배열로 얻을 수 있습니다. 그리고 `array_key_exists()` 함수를 사용하여 배열의 키가 존재하는지 확인할 수 있습니다.

    #hostingforum.kr
    php
    
    $properties = get_object_vars($row);
    
    if (array_key_exists('이름', $properties)) {
    
        echo $row->이름 . "n";
    
    } else {
    
        echo "이름 프로퍼티가 존재하지 않습니다.n";
    
    }
    
    


    5. `json_encode()` 함수를 사용하여 객체를 JSON 문자열로 변환할 수 있습니다. 그리고 `json_decode()` 함수를 사용하여 JSON 문자열을 객체로 변환할 수 있습니다. 그리고 `property_exists()` 함수를 사용하여 객체의 프로퍼티가 존재하는지 확인할 수 있습니다.

    #hostingforum.kr
    php
    
    $json = json_encode($row);
    
    $obj = json_decode($json, true);
    
    if (property_exists($obj, '이름')) {
    
        echo $obj['이름'] . "n";
    
    } else {
    
        echo "이름 프로퍼티가 존재하지 않습니다.n";
    
    }
    
    


    6. `get_class()` 함수를 사용하여 객체의 클래스를 얻을 수 있습니다. 그리고 `class_exists()` 함수를 사용하여 클래스가 존재하는지 확인할 수 있습니다. 그리고 `property_exists()` 함수를 사용하여 클래스의 프로퍼티가 존재하는지 확인할 수 있습니다.

    #hostingforum.kr
    php
    
    $class = get_class($row);
    
    if (class_exists($class) && property_exists($class, '이름')) {
    
        echo $row->이름 . "n";
    
    } else {
    
        echo "이름 프로퍼티가 존재하지 않습니다.n";
    
    }
    
    


    이러한 방법 중 하나를 사용하여 객체의 프로퍼티가 실제로 존재하는지 확인할 수 있습니다.

    2025-07-29 06:33

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

검색

게시물 검색