MySQL LIMIT と OFFSET を使用したページ分割
大規模なデータセットを操作する場合、データをより小さな管理しやすいページに分割すると、ユーザー エクスペリエンスが向上します。ページネーションとして知られるこの手法には、各ページに表示されるレコードの数を制限し、残りのデータを移動するためのナビゲーション オプションを提供することが含まれます。
ページネーションに LIMIT と OFFSET を利用する
MySQL は、ページネーションを実装するための LIMIT 句と OFFSET 句を提供します。 LIMIT は取得する最大行数を指定し、OFFSET は結果セット内の開始位置を決定します。
たとえば、最初のページに 4 つの項目を表示するには、次を使用できます。
SELECT * FROM menuitem LIMIT 4;
2 ページ目の次の 4 つの項目を取得するには、次を使用できます。 OFFSET:
SELECT * FROM menuitem LIMIT 4 OFFSET 4;
合計ページと現在のページの計算
合計ページ数を決定するには、テーブル内の合計行数を知る必要があります。この情報は別のクエリを使用して取得できます:
SELECT COUNT(*) AS total_count FROM menuitem;
合計数を取得したら、合計ページ数を計算できます:
$total_pages = (int)ceil($total_count / $items_per_page);
現在のページを確認するには、次を使用して URL からページ パラメータを読み取ることができます:
$page = filter_input(INPUT_GET, 'page', FILTER_VALIDATE_INT);
ページが提供されていないか無効な場合は、次のように設定します。 1.
動的ページネーションの実装
ページ番号と合計ページを使用して、ページネーション リンクを動的に生成できます。
for ($i = 1; $i <= $total_pages; $i++) { if ($i === $page) { // current page echo 'Page ' . $i . '<br>'; } else { // link to another page echo '<a href="/menuitem.php?page=' . $i . '">Page ' . $i . '</a><br>'; } }
次のようにします。これらの手順を実行すると、ページネーションを効果的かつ動的に実装でき、大規模なデータセットがユーザーフレンドリーな形式で表示されるようになります。
以上がLIMIT と OFFSET を使用して MySQL でページネーションを実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。