- Фильтр Select в php при выводе данных из БД
- Filter results mysql php
- Объектно-ориентированный стиль
- Информация о пользователе
- Список пользователей
- Процедурный стиль
- Информация о пользователе
- Список пользователей
- Выбор и фильтрация данных из БД MySQL
- Фильтрация записей
- Example
- Выборка данных стиле PDO (+ подготовленные операторы)
- Пример
- Операторы сравнения предложения WHERE
- Проверка значений NULL предложения WHERE
Фильтр Select в php при выводе данных из БД
Вот скрипт, он выводит мне таблицу с сортировкой. Пожалуйста, подскажите, что необходимо дописать, чтобы появилась фильтрация по мероприятиям. Т.е select с параметрами «мероприятие1» «мероприятие2» «мероприятие3» и при выборе мероприятия1, в таблице отображалось только данные мероприятия1
select name="course"> option value="Мероприятие1">Мероприятие1/option> option value="Мероприятие2">Мероприятие2/option> option value="Мероприятие3">Мероприятие3/option> /select> $course = $_POST['course']; echo $course; ?>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
// определяем начальные данные $db_host = 'localhost'; $db_name = 'hostite'; $db_username = 'hoin'; $db_password = 'dr4'; $db_table_to_show = 'users'; $result = new PDO('mysql:dbname=hostte;host=localhost', 'hon', 'd4'); // соединяемся с сервером базы данных $connect_to_db = mysqli_connect($db_host, $db_username, $db_password) or die("Could not connect: " . mysql_error()); // подключаемся к базе данных mysqli_select_db($connect_to_db,$db_name) or die("Could not select DB: " . mysql_error()); // выбираем все значения из таблицы $qr_result = $result->prepare("SELECT * FROM `users`") or die(mysql_error()); // выводим на страницу сайта заголовки HTML-таблицы echo ''; echo ''; echo ''; echo 'Мероприятие '; echo 'Имя '; echo 'Фамилия '; echo 'Почта '; echo ' '; echo ''; echo ''; // выводим в HTML-таблицу все данные клиентов из таблицы MySQL while($data = mysqli_fetch_array($qr_result)){ if($data['course'] == $course){ echo ''; echo '' . $data['course'] . ' '; echo '' . $data['first_name'] . ' '; echo '' . $data['last_name'] . ' '; echo '' . $data['email'] . ' '; echo ' '; } } echo ''; echo '
'; // закрываем соединение с сервером базы данных mysqli_close($connect_to_db); ?>
дает ошибку
Warning: mysqli_fetch_array() expects parameter 1 to be mysqli_result, object given in /home/host1818586/host1818586.hostland.pro/htdocs/www/for_admin_filter.php on line 50
Filter results mysql php
Подобно тому, как мы получаем все данные из таблицы, мы можем применять фильтрацию выбирать данные по определенному критерию. Для фильтрации команде SELECT передается выражение WHERE, которая принимает названия столбцов их значения в качестве критерия фильтрации. Например, получение всех данные из таблицы Users, где id = 1 :
SELECT * FROM Users WHERE >Однако если данные для фильтрации приходят извне, нам необходимо учитывать их потенциальную опасность. Рассмотрим получение данных на примере таблицы Users, созданной в прошлых, которая имеет следующее определение:
CREATE TABLE Users (id INTEGER AUTO_INCREMENT PRIMARY KEY, name VARCHAR(30), age INTEGER)
Объектно-ориентированный стиль
Например, мы хотим получать в GET-запросе значение для id и по нему получать из базы данных нужные данные. Определим для этого следующий скрипт user.php :
connect_error)< die("Ошибка: " . $conn->connect_error); > $userid = $conn->real_escape_string($_GET["id"]); $sql = "SELECT * FROM Users WHERE "; if($result = $conn->query($sql))< if($result->num_rows > 0) < foreach($result as $row)< $username = $row["name"]; $userage = $row["age"]; echo ""; > > else< echo "Информация о пользователе
Имя: $username
Возраст: $userage
Пользователь не найден"; > $result->free(); > else< echo "Ошибка: " . $conn->error; > $conn->close(); > ?>
Здесь через запрос GET получаем параметр id — идентификатор пользователя, который надо получить из базы данных. Однако поскольку это значение приходит извне, к нему применяется метод real_escape_string() , который экранирует спецсимволы:
$userid = $conn->real_escape_string($_GET["id"]);
Для упрощения обращения к скрипту определим скрипт index.php , который будет выводить список пользователей с ссылкой на скрипт user.php :
Список пользователей
connect_error)< die("Ошибка: " . $conn->connect_error); > $sql = "SELECT id, name FROM Users"; if($result = $conn->query($sql))< echo "
Имя | |
---|---|
" . $row["name"] . " | "; echo "Подробнее | "; echo "
Таким образом, при обращении к скрипту index.php браузер отобразит список пользователей, а нажав на ссылку рядом с каждым пользователем, мы перейдем к подробному описанию:
Процедурный стиль
$userid = mysqli_real_escape_string($conn, $_GET["id"]); $sql = "SELECT * FROM Users WHERE "; if($result = mysqli_query($conn, $sql)) < if(mysqli_num_rows($result) >0) < foreach($result as $row)< $username = $row["name"]; $userage = $row["age"]; echo ""; > > else< echo "Информация о пользователе
Имя: $username
Возраст: $userage
Пользователь не найден"; > mysqli_free_result($result); > else < echo "Ошибка: " . mysqli_error($conn); >mysqli_close($conn); > ?>
Список пользователей
$sql = "SELECT id, name FROM Users"; if($result = mysqli_query($conn, $sql))< echo "
Имя | |
---|---|
" . $row["name"] . " | "; echo "Подробнее | "; echo "
Выбор и фильтрация данных из БД MySQL
В предыдущих уроках мы выполнили различные операции поиска данных с помощью оператора SELECT, а также рассмотрели, как сортировать результаты поиска. Одно из наиболее важных требований при извлечении данных — это возможность фильтровать эти данные, чтобы возвращались только те строки, которые соответствуют заданным критериям поиска. В MySQL это достигается с помощью предложения WHERE в сочетании с оператором SELECT .
Фильтрация записей
Предложение WHERE используется для извлечения только тех записей, которые соответствуют указанному условию.
Базовый синтаксис предложения WHERE может быть задан следующим образом:
Первая часть оператора очень похожа на любой обычный оператор SELECT . После WHERE нам нужно указать столбец, на котором должны основываться критерии поиска, за которым следует оператор, который указывает тип сравнения, которое нужно выполнить (например, мы ищем равенство) и, наконец, значение, которому столбец должен соответствовать.
Предложение WHERE работает как условие if на любом языке программирования. Это предложение используется для сравнения данного значения со значением поля, доступным в таблице MySQL. Если данное значение извне равно доступному значению поля в таблице MySQL, то он возвращает эту строку.
Давайте сделаем SQL-запрос с использованием предложения WHERE , после чего мы выполним этот запрос, передав его функции PHP mysqli_query() для получения отфильтрованных данных.
У нас есть таблица persons внутри базы данных demo, в которой есть следующие записи:
Следующий код PHP выбирает все строки из таблицы persons, где first_name = ‘john’:
Example
// Попытка выполнения запроса select $sql = "SELECT * FROM persons WHERE first_name='john'"; if($result = mysqli_query($link, $sql)) < if(mysqli_num_rows($result) >0)< echo ""; echo ""; echo "id "; echo "first_name "; echo "last_name "; echo "email "; echo " "; while($row = mysqli_fetch_array($result))< echo ""; echo "" . $row['id'] . " "; echo "" . $row['first_name'] . " "; echo "" . $row['last_name'] . " "; echo "" . $row['email'] . " "; echo " "; > echo "
"; // Закрыть набор результатов mysqli_free_result($result); > else < echo "Записей, соответствующих вашему запросу, не найдено."; >> else < echo "ОШИБКА: не удалось выполнить $sql. " . mysqli_error($link); >// Закрыть соединение mysqli_close($link); ?>
connect_error); > // Попытка выполнения запроса select $sql = "SELECT * FROM persons WHERE first_name='john'"; if($result = $mysqli->query($sql))< if($result->num_rows > 0)< echo ""; echo ""; echo "id "; echo "first_name "; echo "last_name "; echo "email "; echo " "; while($row = $result->fetch_array())< echo ""; echo "" . $row['id'] . " "; echo "" . $row['first_name'] . " "; echo "" . $row['last_name'] . " "; echo "" . $row['email'] . " "; echo " "; > echo "
"; // Доступный набор результатов $result->free(); > else < echo "Записей, соответствующих вашему запросу, не найдено."; >> else< echo "ОШИБКА: не удалось выполнить $sql. " . $mysqli->error; > // Закрыть соединение $mysqli->close(); ?>
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 ""; echo ""; echo "id "; echo "first_name "; echo "last_name "; echo "email "; echo " "; while($row = $result->fetch())< echo ""; echo "" . $row['id'] . " "; echo "" . $row['first_name'] . " "; echo "" . $row['last_name'] . " "; echo "" . $row['email'] . " "; echo " "; > echo "
"; // Доступный набор результатов 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 столбцов.
Выборка данных стиле PDO (+ подготовленные операторы)
В следующем примере используются подготовленные операторы.
Он выбирает столбцы id, first_name, last_name и email из таблицы persons, где last_name=’Carter’, и отображает их в таблице HTML:
Пример
"; echo "Id Имя Фамилия E-mail "; class TableRows extends RecursiveIteratorIterator < function __construct($it) < parent::__construct($it, self::LEAVES_ONLY); >function current() < return "" . parent::current(). " "; > function beginChildren() < echo ""; > function endChildren() < echo " " . "\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 ""; ?>
Результат выполнения кода:
Теперь, когда мы рассмотрели оператор равенства (=), мы можем изучить другие операторы предложения WHERE.
Операторы сравнения предложения WHERE
До сих пор мы рассмотрели только оператор равенства предложения WHERE (=). Это всего лишь один из ряда операторов, которые можно использовать для уточнения поиска данных:
Оператор | Описание |
---|---|
= | Равно |
!= | Не равно |
<> | Не равно |
> | Больше чем |
Меньше чем | |
Меньше или равно | |
>= | Больше или равно |
BETWEEN x AND y | Между значениями x и y |
Например, если мы хотим получить только те продукты из БД, цена которых больше или равна определенному значению, мы могли бы построить инструкцию SQL следующим образом:
Проверка значений NULL предложения WHERE
Помимо возможности проверить значение столбца, также можно проверить столбцы, которые не содержат значения. Считается, что столбцы, не имеющие значений, содержат значения NULL. Поэтому неудивительно, что мы можем проверить наличие пустого столбца, ища равенство с NULL (хотя обратите особое внимание на тот факт, что теперь мы должны использовать IS вместо знака = ):
Любые строки, не содержащие названия продукта, будут извлечены указанным выше оператором SELECT.