>백엔드 개발 >PHP 튜토리얼 >LIMIT 및 OFFSET을 사용하여 MySQL에서 페이지 매김을 어떻게 구현합니까?

LIMIT 및 OFFSET을 사용하여 MySQL에서 페이지 매김을 어떻게 구현합니까?

DDD
DDD원래의
2024-11-17 12:13:01344검색

How do you implement pagination in MySQL using LIMIT and OFFSET?

페이지 매김에 MySQL LIMIT 및 OFFSET 사용

대규모 데이터 세트를 관리 가능한 덩어리로 표시하려면 페이지 매김이 필수적입니다. MySQL은 이 기능을 활성화하기 위해 LIMIT 및 OFFSET라는 두 가지 명령을 제공합니다.

LIMIT는 검색할 최대 행 수를 설정하고, OFFSET은 검색을 시작하기 전에 건너뛸 행 수를 지정합니다. 이를 통해 특정 데이터 페이지를 검색할 수 있습니다.

페이지 매김을 위한 샘플 코드:

페이지당 4개의 항목을 표시하는 다음 코드를 고려하세요.

$result = mysqli_query($con, "SELECT * FROM menuitem LIMIT 4");

이 코드는 menuitem 테이블에서 처음 4개 행을 검색합니다. 여러 페이지를 생성하려면 OFFSET을 사용하여 행을 건너뛸 수 있습니다.

$offset = 4;
$result = mysqli_query($con, "SELECT * FROM menuitem LIMIT 4 OFFSET $offset");

이 코드는 처음 4개 행을 건너뛰고 다음 4개 행을 검색합니다.

총 페이지 수 결정 페이지:

페이지 번호를 하드 코딩하지 않고 페이지 매김을 생성하려면 먼저 총 페이지 수를 결정해야 합니다. 테이블의 총 행 수를 계산하여 이를 달성할 수 있습니다.

$sql = "SELECT COUNT(*) FROM menuitem";
$result = mysqli_query($con, $sql);
$row_count = mysqli_num_rows($result);
// Free the result set
mysqli_free_result($result);

이제 페이지 수를 계산할 수 있습니다.

$items_per_page = 4;
$page_count = (int)ceil($row_count / $items_per_page);

페이지 링크 생성:

알려진 총 페이지 수를 사용하여 페이지를 생성할 수 있습니다. 링크:

for ($i = 1; $i <= $page_count; $i++) {
  if ($i === $page) { // This is the current page
    echo 'Page ' . $i . '<br>';
  } else { // Show link to other page
    echo '<a href="/menuitem.php?page=' . $i . '">Page ' . $i . '</a><br>';
  }
}

이렇게 하면 모든 페이지에 대한 링크가 생성되어 현재 페이지가 강조 표시됩니다.

이 접근 방식을 활용하면 페이지 번호를 하드 코딩하지 않고도 페이지 매김을 생성하고 표시의 유연성을 보장할 수 있습니다. 대규모 데이터 세트.

위 내용은 LIMIT 및 OFFSET을 사용하여 MySQL에서 페이지 매김을 어떻게 구현합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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