개발자 Q&A

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

2025.05.19 08:37

odbc_fetch_array 함수를 사용하여 레코드를 가져올 때 발생하는 오류

목록
  • 취약점헌터 11일 전 2025.05.19 08:37 인기
  • 185
    1
제발 도와주세요.

오라클 데이터베이스에서 odbc_fetch_array 함수를 사용하여 레코드를 가져올 때, 레코드가 하나도 없을 때 에러가 발생하는 이유는 무엇인가요?

예를 들어, 다음과 같은 코드를 사용할 때, 레코드가 하나도 없을 때 odbc_fetch_array 함수는 어떻게 동작하나요?

php

$dsn = "ODBC;DRIVER={Oracle in OraClient12Home1};DBQ=oracleDB";

$uid = "ID";

$pwd = "PW";



$conn = odbc_connect($dsn, $uid, $pwd);

if (!$conn) {

    die("오류");

}



$sql = "SELECT * FROM 테이블명";

$result = odbc_exec($conn, $sql);



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

    echo $row['컬럼명'];

}



위 코드에서 레코드가 하나도 없을 때, odbc_fetch_array 함수는 어떻게 동작하나요?

그리고, 레코드가 하나도 없을 때, 어떻게 에러를 처리할 수 있나요?

제발 도와주세요.

    댓글목록

    profile_image
    나우호스팅  11일 전



    odbc_fetch_array 함수는 레코드를 가져올 때, 레코드가 하나도 없을 때 FALSE를 반환합니다.

    레코드가 하나도 없을 때, while 루프는 실행되지 않습니다.

    레코드가 하나도 없을 때 에러를 처리하려면, while 루프 내에서 레코드가 FALSE인지 확인하여, FALSE인 경우 처리할 수 있습니다.

    예를 들어, 다음과 같이 코드를 수정할 수 있습니다.

    #hostingforum.kr
    php
    
    while ($row = odbc_fetch_array($result)) {
    
        echo $row['컬럼명'];
    
    } else {
    
        echo "레코드가 하나도 없습니다.";
    
    }
    
    


    또는, while 루프를 사용하지 않고, odbc_fetch_array 함수를 반복적으로 호출하여, 레코드가 하나도 없을 때 FALSE를 반환할 때까지 반복할 수 있습니다.

    #hostingforum.kr
    php
    
    while ($row = odbc_fetch_array($result)) {
    
        echo $row['컬럼명'];
    
    }
    
    if ($row === FALSE) {
    
        echo "레코드가 하나도 없습니다.";
    
    }
    
    


    또는, odbc_num_rows 함수를 사용하여, 레코드의 개수를 확인할 수 있습니다.

    #hostingforum.kr
    php
    
    if (odbc_num_rows($result) == 0) {
    
        echo "레코드가 하나도 없습니다.";
    
    } else {
    
        while ($row = odbc_fetch_array($result)) {
    
            echo $row['컬럼명'];
    
        }
    
    }
    
    

    2025-05-19 08:38

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

검색

게시물 검색