집 >데이터 베이스 >MySQL 튜토리얼 >여러 일치 항목이 있는 MySQLi LIKE 쿼리에서 모든 결과를 효율적으로 검색하는 방법은 무엇입니까?
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
루프를 사용한 반복적 접근
이 접근 방식은 각 행을 개별적으로 반복하여 id
및 username
:
<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 중국어 웹사이트의 기타 관련 기사를 참조하세요!