개발자 Q&A

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

2025.03.12 12:59

mysqli_result::fetch_array에 대한 질문

  • UI컴포넌트장인 5일 전 2025.03.12 12:59
  • 1
    1
안녕하세요 선생님. mysqli_result::fetch_array 함수에 대해 궁금한 점이 있습니다.

fetch_array 함수를 사용하여 MySQL 데이터베이스에서 데이터를 가져올 때, fetch_array 함수의 두 번째 인자로 MYSQLI_ASSOC, MYSQLI_NUM, MYSQLI_BOTH를 설정할 수 있습니다.

MYSQLI_ASSOC와 MYSQLI_NUM의 차이점을 알려주실 수 있을까요? MYSQLI_ASSOC는 associative array로 반환되며, MYSQLI_NUM은 numeric array로 반환됩니다.

이러한 두 가지 방식 중 어떤 방식이 더 효율적이고 일반적으로 사용하는 방식은 무엇인지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  5일 전



    mysqli_result::fetch_array 함수의 두 번째 인자로 MYSQLI_ASSOC와 MYSQLI_NUM을 설정할 수 있습니다.

    MYSQLI_ASSOC는 associative array로 반환되며, 이 방식은 데이터베이스에서 가져온 열 이름을 키로 사용할 수 있습니다. 예를 들어, 다음과 같은 데이터베이스 결과를 가정해 보겠습니다.

    | id | name | email |
    | --- | --- | --- |
    | 1 | John | [email protected] |
    | 2 | Jane | [email protected] |

    MYSQLI_ASSOC를 사용하여 데이터를 가져올 경우, 다음과 같이 associative array로 반환됩니다.

    #hostingforum.kr
    php
    
    $result = mysqli_query($conn, "SELECT * FROM users");
    
    $row = mysqli_fetch_array($result, MYSQLI_ASSOC);
    
    print_r($row);
    
    


    출력 결과는 다음과 같습니다.

    #hostingforum.kr
    php
    
    Array
    
    (
    
        [id] => 1
    
        [name] => John
    
        [email] => [email protected]
    
    )
    
    


    반면, MYSQLI_NUM은 numeric array로 반환됩니다. 이 방식은 데이터베이스에서 가져온 열의 순서를 키로 사용합니다.

    #hostingforum.kr
    php
    
    $result = mysqli_query($conn, "SELECT * FROM users");
    
    $row = mysqli_fetch_array($result, MYSQLI_NUM);
    
    print_r($row);
    
    


    출력 결과는 다음과 같습니다.

    #hostingforum.kr
    php
    
    Array
    
    (
    
        [0] => 1
    
        [1] => John
    
        [2] => [email protected]
    
    )
    
    


    두 가지 방식 중 MYSQLI_ASSOC가 더 효율적이고 일반적으로 사용하는 방식입니다. 이유는 다음과 같습니다.

    - 데이터베이스에서 가져온 열 이름을 키로 사용할 수 있기 때문에, 코드가 더 직관적이고 읽기 쉬워집니다.
    - 데이터베이스에서 가져온 열 이름을 키로 사용할 수 있기 때문에, 코드가 더 유지보수하기 쉽습니다.
    - MYSQLI_ASSOC를 사용할 경우, 데이터베이스에서 가져온 열 이름을 키로 사용할 수 있기 때문에, 코드가 더 빠르게 실행됩니다.

    하지만, MYSQLI_ASSOC를 사용할 경우, 데이터베이스에서 가져온 열 이름이 변경된 경우, 코드가 오류를 발생할 수 있습니다. 따라서, 데이터베이스에서 가져온 열 이름이 변경되지 않는 경우, MYSQLI_ASSOC를 사용하는 것이 좋습니다.

    2025-03-12 13:00

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

검색

게시물 검색