>데이터 베이스 >MySQL 튜토리얼 >MySQLi의 `bind_result`와 `get_result`: 어떤 방법을 선택해야 합니까?

MySQLi의 `bind_result`와 `get_result`: 어떤 방법을 선택해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-11 12:34:11984검색

`bind_result` vs. `get_result` in MySQLi: Which Method Should You Choose?

MySQLi에서 바인드 결과와 get_result의 차이점

MySQLi는 쿼리 결과에서 데이터를 검색하는 두 가지 방법인 바인드 결과와 get_result를 제공합니다. 각 방법에는 고유한 장점과 단점이 있으며 아래에 설명되어 있습니다.

bind_result

Bind_result는 변수를 쿼리 결과의 열에 바인딩합니다. 이는 결과의 개별 값으로 작업하려는 경우 유용할 수 있습니다.

구문:

$stmt = $mysqli->prepare($query);
$stmt->bind_result($var1, $var2, $var3);
$stmt->execute();
while ($stmt->fetch()) {
    // Do something with $var1, $var2, and $var3
}

bind_result의 장점:

  • PHP 5.3 및 나중에
  • 각 열에 대해 별도의 변수를 반환합니다
  • 몇 개의 열만 작업해야 하는 경우 get_result보다 더 효율적일 수 있습니다

bind_result의 단점 :

  • 모든 항목을 수동으로 나열해야 합니다. 쿼리의 열
  • 행을 배열로 반환해야 하는 경우 더 장황해질 수 있음
  • 테이블 구조가 변경되면 코드 변경 필요

get_result

Get_result는 쿼리 결과를 나타내는 개체 또는 배열을 반환합니다. 결과 전체를 사용하여 작업하려는 경우 이것은 bin_result보다 더 편리할 수 있습니다.

구문:

$stmt = $mysqli->prepare($query);
$stmt->execute();
$result = $stmt->get_result();
while ($row = $result->fetch_assoc()) {
    // Do something with $row
}

get_result의 장점:

  • 반환 반환된 행의 데이터로 자동으로 채워지는 연관/열거형 배열 또는 객체
  • fetch_all() 메서드를 사용하여 반환된 모든 행을 한 번에 검색할 수 있습니다

get_result의 단점:

  • PHP 필요 5.5 이상
  • 몇 개의 열만 작업해야 하는 경우 바인딩_result보다 효율성이 떨어질 수 있습니다

위 내용은 MySQLi의 `bind_result`와 `get_result`: 어떤 방법을 선택해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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