>백엔드 개발 >PHP 튜토리얼 >MySQL Fetch Array가 쿼리 결과의 첫 번째 행만 검색하는 이유는 무엇입니까?

MySQL Fetch Array가 쿼리 결과의 첫 번째 행만 검색하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-20 14:31:29988검색

Why Does MySQL Fetch Array Only Retrieve the First Row of a Query Result?

MySQL Fetch Array는 제한된 행을 검색합니다

제공된 코드는 PHP의 MySQL 확장을 사용하여 데이터베이스에서 여러 행을 검색하는 것을 목표로 합니다. 그러나 첫 번째 행에만 액세스할 수 있는 문제가 발생합니다. 쿼리는 'a', 'b' 또는 'c'로 시작하는 아티스트를 검색합니다. 그러나 이후에 첫 번째 이후의 행에 액세스하려고 시도하면 정의되지 않은 오프셋 오류가 발생합니다.

이 문제의 원인은 mysql_fetch_array 함수의 기능에 있습니다. 결과 집합의 단일 행을 연관 및 인덱스 배열로 반환합니다. 여러 행에 액세스하려면 모든 행이 처리될 때까지 함수를 반복적으로 호출해야 합니다.

다음 수정된 코드 조각은 결과 집합의 모든 행을 반복하는 방법을 보여줍니다.

<code class="php">$array = mysql_query("SELECT artist FROM directory WHERE artist LIKE 'a%' 
        OR artist LIKE 'b%' 
        OR artist LIKE 'c%'");

while ($array_result = mysql_fetch_array($array)) {
    echo $array_result[0] . "\n";
    // Additional processing for each row can be performed here.
}</code>

이 코드에서 while 루프는 결과 집합에서 검색할 행이 더 이상 없을 때까지 mysql_fetch_array를 계속 호출합니다. 이를 통해 코드는 필요에 따라 각 행을 처리할 수 있습니다.

위 내용은 MySQL Fetch Array가 쿼리 결과의 첫 번째 행만 검색하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.