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 && $row <= ($numrows-1) && $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 중국어 웹사이트의 기타 관련 기사를 참조하세요!