집 >데이터 베이스 >MySQL 튜토리얼 >PHP에서 MySQL 데이터베이스의 마지막 5개 BLOB 이미지를 표시하는 방법은 무엇입니까?
MySQL 데이터베이스에서 BLOB 이미지 표시
질문에서 MySQL 데이터베이스 테이블에 업로드된 마지막 5개의 BLOB 이미지를 표시하는 데 관심을 표명하셨습니다. "스토어"라는 이름을 붙였습니다. PHP 및 데이터베이스 처리의 초보자로서 이 작업은 어렵게 보일 수 있습니다. 관리 가능한 단계로 나누어 보겠습니다.
MySQL에 이미지 저장
데이터베이스에 이미지를 저장하는 코드가 작동하는 것 같습니다. 업로드된 파일의 바이너리 데이터를 읽으려면 file_get_contents()를 사용하고 특수 문자를 이스케이프하려면lashes()를 추가합니다. 그런 다음 이 데이터를 이미지 이름 및 크기와 함께 "store" 테이블에 삽입합니다.
마지막 5개 이미지 검색
최근 업로드된 5개 이미지를 검색하려면, 다음과 같은 MySQL 쿼리를 사용할 수 있습니다.
<code class="sql">SELECT id, image FROM store ORDER BY id DESC LIMIT 5</code>
이 쿼리는 결과를 id 열의 내림차순으로 정렬하여 삽입된 마지막 5개 이미지를 효과적으로 가져옵니다.
이미지
웹페이지에 이미지를 표시하려면 다음 PHP 코드를 사용할 수 있습니다.
<code class="php">$result = mysqli_query($db, $sql); // Execute the SQL query while ($row = mysqli_fetch_assoc($result)) { // Iterate over the result rows echo "<img src='get.php?id=" . $row['id'] . "' />"; // Display the image using the `get.php` script }</code>
위 코드는 while 루프를 사용하여 결과 행을 반복하고 각 행에 img 태그를 표시합니다. 이미지 소스는 데이터베이스에서 실제 이미지 데이터를 가져오는 별도의 PHP 스크립트인 get.php로 설정됩니다.
get.php 스크립트
get.php 스크립트는 다음과 같아야 합니다.
<code class="php">$id = addslashes($_GET['id']); // Get the image ID from the URL $image = mysqli_query($db, "SELECT image FROM store WHERE id=$id"); // Fetch the image data $image = mysqli_fetch_assoc($image); // Retrieve the image data as an array header("Content-type: image/jpeg"); // Set the content type for the image echo $image['image']; // Output the binary image data</code>
이 스크립트는 지정된 ID에 대한 이미지 데이터를 가져와서 올바른 MIME 유형으로 출력하여 브라우저가 이미지를 렌더링할 수 있도록 합니다.
결론
이 단계를 따르면 PHP의 MySQL 데이터베이스에 업로드된 마지막 5개의 이미지 갤러리를 성공적으로 표시할 수 있습니다. 테이블 및 열 이름에 따라 SQL 쿼리와 PHP 코드를 조정하고 특히 대용량 이미지 파일로 작업하는 경우 성능을 위해 코드를 최적화하는 것을 고려하세요.
위 내용은 PHP에서 MySQL 데이터베이스의 마지막 5개 BLOB 이미지를 표시하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!