>데이터 베이스 >MySQL 튜토리얼 >여러 일치 항목이 있는 MySQLi LIKE 쿼리에서 모든 결과를 효율적으로 검색하는 방법은 무엇입니까?

여러 일치 항목이 있는 MySQLi LIKE 쿼리에서 모든 결과를 효율적으로 검색하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-20 06:08:081022검색

How to Efficiently Retrieve All Results from a MySQLi LIKE Query with Multiple Matches?

MySQLi LIKE 쿼리에서 모든 일치 항목 검색

PHP에서 MySQLi LIKE 쿼리로 작업할 때, 특히 여러 결과가 예상되는 경우 일치하는 모든 레코드가 검색되도록 주의 깊게 처리해야 합니다. 다음은 이를 달성하는 효율적인 방법을 보여줍니다.

일반적인 실수는 첫 번째 결과만 가져오는 것입니다. 일치하는 모든 행을 검색하려면 다음과 같은 향상된 기술을 사용하십시오.

방법 1: fetch_all() 사용(권장)

이 방법은 특히 PHP 8.2 이상에서 간결하고 효율적입니다. 모든 결과를 연관 배열로 가져옵니다.

<code class="language-php">$param = "%{$_POST['user']}%";
$stmt = $db->prepare("SELECT id, username FROM users WHERE username LIKE ?");
$stmt->bind_param("s", $param);
$stmt->execute();
$result = $stmt->get_result();
$data = $result->fetch_all(MYSQLI_ASSOC); // Fetches all results</code>

PHP 8.2의 경우 execute_query 함수를 사용하면 이를 더욱 단순화할 수 있습니다.

<code class="language-php">$sql = "SELECT id, username FROM users WHERE username LIKE ?";
$result = $db->execute_query($sql, ["%{$_POST['user']}%"]);
$data = $result->fetch_all(MYSQLI_ASSOC);</code>

방법 2: bind_result()while 루프를 사용한 반복적 접근

이 접근 방식은 각 행을 개별적으로 반복하여 idusername:

을 인쇄합니다.
<code class="language-php">$stmt->bind_result($id, $username);
while ($stmt->fetch()) {
  echo "Id: {$id}, Username: {$username}<br>"; // Added <br> for better output
}</code>

이 방법은 모든 행을 배열에 저장하는 대신 각 행을 개별적으로 처리해야 하는 경우에 유용합니다.

두 방법 모두 공식 MySQLi 문서를 기반으로 하며 LIKE 쿼리의 여러 결과를 처리하기 위한 강력한 솔루션을 제공합니다. fetch_all() 방법은 모든 결과를 한 번에 검색하는 단순성과 효율성 때문에 일반적으로 선호됩니다.

위 내용은 여러 일치 항목이 있는 MySQLi LIKE 쿼리에서 모든 결과를 효율적으로 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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