>  기사  >  백엔드 개발  >  PHP의 `mysql_result()` 함수를 MySQLi로 바꾸는 방법은 무엇입니까?

PHP의 `mysql_result()` 함수를 MySQLi로 바꾸는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-25 13:29:11893검색

How to Replace PHP's `mysql_result()` Function with MySQLi?

MySQLi에서 PHP의 mysql_result() 함수 기능을 복제하는 방법

레거시 PHP 코드에서 일반적으로 사용되는 mysql_result() 함수는, 개발자는 MySQL 쿼리 결과에서 특정 데이터에 빠르게 액세스할 수 있습니다. 그러나 이 기능은 MySQL 데이터베이스와 상호 작용하기 위해 개선되고 권장되는 확장인 MySQLi에서 기본적으로 지원되지 않습니다.

행 가져오기를 통한 대체 접근 방식

검색에 대한 일반적인 접근 방식 중 하나 MySQLi 쿼리 결과의 데이터는 fetch_assoc() 메서드를 사용하여 해당 행을 가져오는 것입니다. 예는 다음과 같습니다.

if ($r && $r->num_rows) {
    $row = $r->fetch_assoc();
    $blarg = $row['blah'];
}

이 접근 방식에는 여러 줄이 필요하며 mysql_result()와 같은 전용 함수를 사용하는 것보다 효율성이 떨어질 수 있습니다.

사용자 정의 등가 함수

MySQLi에서 mysql_result()의 기능을 복제하려면 다음과 같이 사용자 정의 함수를 생성할 수 있습니다. 아래:

function mysqli_result($res,$row=0,$col=0){ 
    $numrows = mysqli_num_rows($res); 
    if ($numrows &amp;&amp; $row <= ($numrows-1) &amp;&amp; $row >=0){
        mysqli_data_seek($res,$row);
        $resrow = (is_numeric($col)) ? mysqli_fetch_row($res) : mysqli_fetch_assoc($res);
        if (isset($resrow[$col])){
            return $resrow[$col];
        }
    }
    return false;
}

이 함수는 행 및 열 인덱스를 매개 변수로 받아들이고 해당 데이터가 있으면 해당 데이터를 반환합니다. 또한 범위를 벗어난 요청과 관련된 잠재적인 오류도 처리합니다.

사용법:

mysqli_result() 함수는 mysql_result()와 비슷한 방식으로 사용할 수 있습니다. :

if ($r && $r->num_rows)  
    $blarg = mysqli_result($r, 0, 'blah');

혜택 및 제한 사항

사용자 정의 mysqli_result() 함수를 사용하면 코드를 더욱 간결하게 만들고 MySQLi 쿼리 결과에서 데이터를 검색하는 데 필요한 줄 수를 줄일 수 있습니다. 그러나 이 함수는 PHP의 동적 함수 호출에 의존하며 원래 mysql_result() 구현에 비해 약간의 성능 저하가 발생할 수 있다는 점에 유의해야 합니다.

위 내용은 PHP의 `mysql_result()` 함수를 MySQLi로 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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