>데이터 베이스 >MySQL 튜토리얼 >`mysqli` 준비된 명령문: `bind_result()` 또는 `get_result()`?

`mysqli` 준비된 명령문: `bind_result()` 또는 `get_result()`?

Patricia Arquette
Patricia Arquette원래의
2024-12-25 09:22:13231검색

`mysqli` Prepared Statements: `bind_result()` or `get_result()`?

Bind_result와 Get_result: 어느 것을 사용할 것인가?

소개

mysqli에서 준비된 문으로 작업할 때 결과를 가져오는 두 가지 옵션이 있습니다. : 바인딩_결과() 및 get_result(). 데이터베이스 작업을 최적화하려면 이러한 방법 간의 차이점을 이해하는 것이 중요합니다.

Bind_result()

bind_result()는 특정 변수를 쿼리 결과의 열에 바인딩하여 사용자가 이를 직접 할당할 수 있도록 합니다. 스칼라 변수. 쿼리에서 특정 열이 필요할 때 일반적으로 사용됩니다.

예:

$query = 'SELECT id, first_name, last_name FROM table WHERE id = ?';
$id = 5;

$stmt = $mysqli->prepare($query);
$stmt->bind_param('i', $id);
$stmt->execute();
$stmt->store_result();
$stmt->bind_result($id, $first_name, $last_name);

장점:

  • 오래된 PHP 버전에서 작동합니다.
  • 반환 각 열마다 별도의 변수가 필요합니다.

단점:

  • 바인딩할 모든 변수를 수동으로 나열해야 합니다.
  • 추가 필요 행을 배열로 반환하는 코드입니다.
  • 테이블 구조가 변경될 때 업데이트해야 합니다. 변경됩니다.

Get_result()

get_result()는 전체 결과를 연관 또는 열거형 배열로 검색하며 반환된 행의 데이터로 자동으로 채워집니다. 전체 행을 배열로 작업해야 할 때 편리합니다.

예:

$query = 'SELECT * FROM table WHERE id = ?';
$id = 5;

$stmt = $mysqli->prepare($query);
$stmt->bind_param('i', $id);
$stmt->execute();
$result = $stmt->get_result();

장점:

  • 연관/열거 배열 또는 객체를 반환합니다.
  • 반환된 모든 행을 한 번에 검색하기 위해 fetch_all()을 지원합니다.

단점:

  • MySQL 네이티브 필요 드라이버(mysqlnd).

제한 사항 및 차이점

두 방법 모두 제한 사항이 있습니다.

  • bind_result()에는 명시적인 열 나열이 필요하므로 오류가 발생하기 쉽고 유연성이 없습니다.
  • get_result()는 지원하지 않습니다. 오래된 PHP 버전이며 MySQL 기본 드라이버가 필요합니다.

올바른 선택 방법

가장 좋은 방법은 특정 요구 사항에 따라 다릅니다.

  • 특정 열에 대해 별도의 변수가 필요하고 이전 PHP 버전에서 작업하는 경우에는 바인딩_result()를 사용하세요.
  • 행을 배열로 작업하는 것을 선호하고 모든 행을 한 번에 검색하고 MySQL 기본 드라이버가 있는 경우 다음을 사용하십시오. get_result().

위 내용은 `mysqli` 준비된 명령문: `bind_result()` 또는 `get_result()`?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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