>데이터 베이스 >MySQL 튜토리얼 >PHP에서 MySQL 데이터베이스의 마지막 5개 BLOB 이미지를 표시하는 방법은 무엇입니까?

PHP에서 MySQL 데이터베이스의 마지막 5개 BLOB 이미지를 표시하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-30 15:15:03963검색

How to Display the Last Five BLOB Images from a MySQL Database in PHP?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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