MySQL LIMIT, OFFSET with Response를 사용한 페이지 매김
페이지 매김을 사용하면 웹 개발의 일반적인 기술인 대규모 데이터 세트를 더 작고 관리 가능한 페이지로 분할할 수 있습니다. . MySQL은 페이지 매김을 처리하기 위해 LIMIT 및 OFFSET 절을 제공합니다.
문제:
페이지별로 미리 정의된 항목 수를 사용하여 데이터베이스 테이블의 데이터를 표시하려면 여러 페이지를 생성해야 합니다. 페이지이지만 페이지 매김을 하드코딩하지 않고 logic.
해결책:
다음과 같이 URL에 페이지 매기기 매개변수를 사용하세요.
http://yoursite.com/itempage.php?page=2
다음을 사용하여 요청된 페이지 번호에 액세스할 수 있습니다. $_GET['page'].
페이지를 기반으로 오프셋을 동적으로 계산하도록 SQL 쿼리를 수정하세요. number:
// determine page number from $_GET $page = 1; if(!empty($_GET['page'])) { $page = filter_input(INPUT_GET, 'page', FILTER_VALIDATE_INT); if(false === $page) { $page = 1; } } // set the number of items to display per page $items_per_page = 4; // build query $offset = ($page - 1) * $items_per_page; $sql = "SELECT * FROM menuitem LIMIT " . $offset . "," . $items_per_page;
총 페이지 수를 결정하려면 테이블의 행 수를 계산해야 합니다.
$sql = "SELECT your_primary_key_field FROM menuitem"; $result = mysqli_query($con, $sql); $row_count = mysqli_num_rows($result); // free the result set as you don't need it anymore mysqli_free_result($result); $page_count = 0; if (0 === $row_count) { // maybe show some error since there is nothing in your table } else { // determine page_count $page_count = ceil($row_count / $items_per_page); // double check that request page is in range if($page > $page_count) { // error to user, maybe set page to 1 $page = 1; } }
페이지가 매겨진 데이터를 표시할 때 다음을 사용할 수 있습니다. 적절한 링크를 생성하기 위한 $page 및 $page_count 변수:
// later when outputting page, you can simply work with $page and $page_count to output links // for example for ($i = 1; $i <= $page_count; $i++) { if ($i === $page) { // this is current page echo 'Page ' . $i . '<br>'; } else { // show link to other page echo '<a href="/menuitem.php?page=' . $i . '">Page ' . $i . '</a><br>'; } }
위 내용은 MySQL의 LIMIT 및 OFFSET을 사용하여 PHP에서 데이터베이스 페이지 매김을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!