PHP Учебник

PHP Старт Введение в PHP Установка PHP Синтаксис PHP Комментарии в PHP Переменные PHP PHP Echo / Print Типы данных PHP Строки PHP Числа PHP Математика в PHP Константы PHP Операторы PHP PHP If...Else...Elseif PHP Switch Циклы в PHP Функции PHP Массивы PHP PHP Суперглобальные PHP RegEx

PHP Формы

Обработка форм PHP Валидация форм PHP Обязательные поля Валидация URL/E-mail Полная форма PHP

PHP Продвинутый

PHP Дата и время PHP Include/Require PHP Работа с файлами Открытие/Чтение файлов Создание/Запись файлов PHP Загрузка файлов Файлы cookie PHP Сессии PHP Фильтры PHP Расширенные фильтры PHP Функция Callback PHP JSON PHP Исключения

PHP OOP

Что такое ООП в PHP Классы/Объекты PHP Цепочки методов PHP Конструктор PHP Деструктор PHP Модификаторы доступа Наследование в PHP Константы класса PHP Подсказка типов PHP Подсказка интерфейсов Абстрактные классы PHP PHP Интерфейсы PHP Полиформизм PHP Трейты Статические методы PHP Статические свойства PHP Пространства имен PHP Итерируемые объекты

База данных MySQL

База данных MySQL Подключение к MySQL Создание БД MySQL Создание таблицы MySQL Вставка данных MySQL Получить ID MySQL Подготовленные операторы PHP MySQL Получение данных MySQL Предложение WHERE Предложение ORDER BY Обновление данных MySQL Удаление данных БД MySQL Limit Data

PHP XML

Парсеры PHP XML Парсер PHP SimpleXML Получить PHP SimpleXML PHP XML Expat PHP XML DOM

PHP - AJAX

AJAX Введение AJAX PHP AJAX База Данных AJAX XML AJAX Живой поиск AJAX Опрос

PHP Примеры

PHP Примеры Практика ООП PHP PHP квиз-тест Упражнения Базовый PHP Упражнения Алгоритмы Упражнения Массивы Упражнения Цикл for Упражнения Функции Регулярные выражения Упражнения Дата PHP Упражнения Строки PHP Математика PHP Упражнения Формы PHP Упражнения Классы PHP Упражнения JSON PHP PHP Задачник


Ограничение количество выводимых записей MySQL




В этом уроке вы узнаете, как получить ограниченное количество записей из таблицы базы данных MySQL с помощью условия LIMIT.


Условие LIMIT используется для ограничения количества строк, возвращаемых оператором SELECT. Эта функция очень полезна для оптимизации времени загрузки страницы, а также для повышения читабельности веб-сайта. Например, вы можете разделить большое количество записей на несколько страниц, используя разбиение на страницы, где ограниченное количество записей будет загружено на каждую страницу из базы данных, когда пользователь запросит эту страницу, щелкнув ссылку разбиения на страницы.

Базовый синтаксис условия LIMIT может быть задан следующим образом:

SELECT column_name(s) FROM table_name LIMIT row_offset, row_count;

Условие LIMIT принимает один или два параметра, которые должны быть неотрицательным целым числом:

  • Если указаны два параметра, первый параметр указывает смещение первой возвращаемой строки, то есть начальную точку, тогда как второй параметр указывает количество возвращаемых строк. Смещение первой строки равно 0 (а не 1).
  • В то время, когда указан только один параметр, он определяет максимальное количество строк, возвращаемых с начала набора результатов.

Например, чтобы получить первые 4 строки, вы можете использовать следующий запрос:

SELECT * FROM persons LIMIT 4;

Чтобы получить строки от 16 до 25 (включительно), вы можете использовать оператор OFFSET:

В приведенном ниже SQL-запросе говорится: вернуть только 10 записей, начать с записи 16 (OFFSET 15):

SELECT * FROM persons LIMIT 10 OFFSET 15;

Вы также можете использовать более короткий синтаксис для достижения того же результата:

SELECT * FROM persons LIMIT 15, 10;
Обратите внимание, что при использовании запятой числа меняются местами.

Давайте сделаем SQL-запрос, используя условие LIMIT в операторе SELECT, после чего мы выполним этот запрос, передав его функции PHP mysqli_query(), чтобы получить ограниченное количество записей. Рассмотрим следующую таблицу persons в БД demo:

Выбор данных из таблиц базы данных MySQL

Код PHP в следующем примере будет отображаться только две строки из таблицы persons:

Пример

Процедурный Объектно-ориентированный PDO
Скопировать
<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "demo";

// Создать соединение
$conn = mysqli_connect($servername, $username, $password, $dbname);
// Проверьте подключение
if (!$conn) {
  die("Ошибка подключения: " . mysqli_connect_error());
}
 
// Попытка выполнения запроса select
$sql = "SELECT * FROM persons LIMIT 2";
if($result = mysqli_query($conn, $sql)){
    if(mysqli_num_rows($result) > 0){
        echo "<table>";
            echo "<tr>";
                echo "<th>id</th>";
                echo "<th>first_name</th>";
                echo "<th>last_name</th>";
                echo "<th>email</th>";
            echo "</tr>";
        while($row = mysqli_fetch_array($result)){
            echo "<tr>";
                echo "<td>" . $row['id'] . "</td>";
                echo "<td>" . $row['first_name'] . "</td>";
                echo "<td>" . $row['last_name'] . "</td>";
                echo "<td>" . $row['email'] . "</td>";
            echo "</tr>";
        }
        echo "</table>";
        // Закрыть набор результатов
        mysqli_free_result($result);
    } else{
        echo "Записей, соответствующих вашему запросу, не найдено.";
    }
} else{
    echo "ОШИБКА: не удалось выполнить $sql. " . mysqli_error($conn);
}
 
// Закрыть соединение
mysqli_close($conn);
?>
<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "demo";

// Создать соединение
$conn = mysqli_connect($servername, $username, $password, $dbname);
// Проверьте подключение
if (!$conn) {
  die("Ошибка подключения: " . mysqli_connect_error());
}
 
// Попытка выполнения запроса select
$sql = "SELECT * FROM persons LIMIT 2";
if($result = $mysqli->query($sql)){
    if($result->num_rows > 0){
        echo "<table>";
            echo "<tr>";
                echo "<th>id</th>";
                echo "<th>first_name</th>";
                echo "<th>last_name</th>";
                echo "<th>email</th>";
            echo "</tr>";
        while($row = $result->fetch_array()){
            echo "<tr>";
                echo "<td>" . $row['id'] . "</td>";
                echo "<td>" . $row['first_name'] . "</td>";
                echo "<td>" . $row['last_name'] . "</td>";
                echo "<td>" . $row['email'] . "</td>";
            echo "</tr>";
        }
        echo "</table>";
        // Free result set
        $result->free();
    } else{
        echo "Записей, соответствующих вашему запросу, не найдено.";
    }
} else{
    echo "ОШИБКА: не удалось выполнить $sql. " . $mysqli->error;
}
 
// Закрыть соединение
$mysqli->close();
?>
<?php
try{
    $pdo = new PDO("mysql:host=localhost;dbname=demo", "root", "");
    // Установите режим ошибки PDO в исключение
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch(PDOException $e){
    die("ОШИБКА: не удалось подключиться. " . $e->getMessage());
}
 
// Попытка выполнения запроса select
try{
    $sql = "SELECT * FROM persons LIMIT 2";  
    $result = $pdo->query($sql);
    if($result->rowCount() > 0){
        echo "<table>";
            echo "<tr>";
                echo "<th>id</th>";
                echo "<th>first_name</th>";
                echo "<th>last_name</th>";
                echo "<th>email</th>";
            echo "</tr>";
        while($row = $result->fetch()){
            echo "<tr>";
                echo "<td>" . $row['id'] . "</td>";
                echo "<td>" . $row['first_name'] . "</td>";
                echo "<td>" . $row['last_name'] . "</td>";
                echo "<td>" . $row['email'] . "</td>";
            echo "</tr>";
        }
        echo "</table>";
        // Доступный набор результатов
        unset($result);
    } else{
        echo "Записей, соответствующих вашему запросу, не найдено.";
    }
} catch(PDOException $e){
    die("ОШИБКА: не удалось выполнить $sql. " . $e->getMessage());
}
 
// Закрыть соединение
unset($pdo);
?>

После выполнения сценария результат вывода будет выглядеть так:

+----+------------+-----------+----------------------+
| id | first_name | last_name | email                |
+----+------------+-----------+----------------------+
|  1 | Peter      | Parker    | peterparker@mail.com |
|  2 | John       | Rambo     | johnrambo@mail.com   |
+----+------------+-----------+----------------------+