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




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


Предложение WHERE используется для извлечения только тех записей, которые соответствуют указанному условию.

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

SELECT column_name(s) FROM table_name WHERE column_name operator value

Первая часть оператора очень похожа на любой обычный оператор SELECT. После WHERE нам нужно указать столбец, на котором должны основываться критерии поиска, за которым следует оператор, который указывает тип сравнения, которое нужно выполнить (например, мы ищем равенство) и, наконец, значение, которому столбец должен соответствовать.

Предложение WHERE работает как условие if на любом языке программирования. Это предложение используется для сравнения данного значения со значением поля, доступным в таблице MySQL. Если данное значение извне равно доступному значению поля в таблице MySQL, то он возвращает эту строку.

Давайте сделаем SQL-запрос с использованием предложения WHERE, после чего мы выполним этот запрос, передав его функции PHP mysqli_query() для получения отфильтрованных данных.

У нас есть таблица persons внутри базы данных demo, в которой есть следующие записи:

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

Следующий код PHP выбирает все строки из таблицы persons, где first_name = 'john':

Example

Процедурный Объектно-ориентированный PDO
Скопировать
<?php
/* Попытка подключения к серверу MySQL. Предполагая, что вы используете MySQL
 сервер с настройкой по умолчанию (пользователь root без пароля)  */
$link = mysqli_connect("localhost", "root", "", "demo");
 
// Проверка подключения
if($link === false){
    die("Ошибка подключения. " . mysqli_connect_error());
}
 
// Попытка выполнения запроса select
$sql = "SELECT * FROM persons WHERE first_name='john'";
if($result = mysqli_query($link, $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($link);
}
 
// Закрыть соединение
mysqli_close($link);
?>
<?php
/* Попытка подключения к серверу MySQL. Предполагая, что вы используете MySQL
 сервер с настройкой по умолчанию (пользователь root без пароля) */
$mysqli = new mysqli("localhost", "root", "", "demo");
 
// Проверьте подключение
if($mysqli === false){
    die("ОШИБКА: не удалось подключиться. " . $mysqli->connect_error);
}
 
// Попытка выполнения запроса select
$sql = "SELECT * FROM persons WHERE first_name='john'";
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>";
        // Доступный набор результатов
        $result->free();
    } else{
        echo "Записей, соответствующих вашему запросу, не найдено.";
    }
} else{
    echo "ОШИБКА: не удалось выполнить $sql. " . $mysqli->error;
}
 
// Закрыть соединение
$mysqli->close();
?>
<?php
/* Попытка подключения к серверу MySQL. Предполагая, что вы используете MySQL
 сервер с настройкой по умолчанию (пользователь root без пароля) */
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 WHERE first_name='john'";  
    $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               |
+----+------------+-----------+---------------------+
|  2 | John       | Rambo     | johnrambo@mail.com  |
|  4 | John       | Carter    | johncarter@mail.com |
+----+------------+-----------+---------------------+

Объяснение кода из приведенного выше примера:

Сначала мы настраиваем SQL-запрос, который выбирает столбцы id, first_name, last_name и email из таблицы persons, где first_name='john'. Следующая строка кода выполняет запрос и помещает полученные данные в переменную с именем $result.

Затем функция mysqli_num_rows() проверяет, было ли возвращено строк больше нуля.

Если возвращается строк более нуля, функция fetch_assoc() помещает все результаты в ассоциативный массив, который мы можем просмотреть. В цикл while() через результирующий набор выводит данные из id, first_name, last_name и email столбцов.

В следующем примере используются подготовленные операторы.

Он выбирает столбцы id, first_name, last_name и email из таблицы persons, где last_name='Carter', и отображает их в таблице HTML:

<?php
echo "<table style='border: solid 1px black;'>";
echo "<tr><th>Id</th><th>Имя</th><th>Фамилия</th><th>E-mail</th></tr>";

class TableRows extends RecursiveIteratorIterator { 
  function __construct($it) { 
    parent::__construct($it, self::LEAVES_ONLY); 
  }

  function current() {
    return "<td style='width: 150px; border: 1px solid black;'>" . parent::current(). "</td>";
  }

  function beginChildren() { 
    echo "<tr>"; 
  } 

  function endChildren() { 
    echo "</tr>" . "\n";
  } 
} 

$serverName = "localhost";
$userName = "root";
$password = "";
$dbName = "demo";

try {
  $conn = new PDO("mysql:host=$serverName;dbname=$dbName", $userName, $password);
  $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  $stmt = $conn->prepare("SELECT id, first_name, last_name, email FROM persons WHERE last_name='Carter'"); 
  $stmt->execute();

  // поместить результат в ассоциативный массив 
  $result = $stmt->setFetchMode(PDO::FETCH_ASSOC); 

  foreach(new TableRows(new RecursiveArrayIterator($stmt->fetchAll())) as $k=>$v) { 
    echo $v;
  }
}
catch(PDOException $e) {
  echo "Error: " . $e->getMessage();
}
$conn = null;
echo "</table>";
?>

Результат выполнения кода:

IdИмяФамилияE-mail
4JohnCarterjohncarter@mail.com

Теперь, когда мы рассмотрели оператор равенства (=), мы можем изучить другие операторы предложения WHERE.

До сих пор мы рассмотрели только оператор равенства предложения WHERE (=). Это всего лишь один из ряда операторов, которые можно использовать для уточнения поиска данных:

ОператорОписание
=Равно
!=Не равно
<>Не равно
>Больше чем
<Меньше чем
<=Меньше или равно
>=Больше или равно
BETWEEN x AND yМежду значениями x и y

Например, если мы хотим получить только те продукты из БД, цена которых больше или равна определенному значению, мы могли бы построить инструкцию SQL следующим образом:

SELECT column_name(s) FROM products WHERE prod_price >= 490

Помимо возможности проверить значение столбца, также можно проверить столбцы, которые не содержат значения. Считается, что столбцы, не имеющие значений, содержат значения NULL. Поэтому неудивительно, что мы можем проверить наличие пустого столбца, ища равенство с NULL (хотя обратите особое внимание на тот факт, что теперь мы должны использовать IS вместо знака = ):

SELECT * FROM products WHERE prod_name IS NULL

Любые строки, не содержащие названия продукта, будут извлечены указанным выше оператором SELECT.