Поиск в базе PHP или как я остался без вкуснейшего бутерброда!
От автора: хорошо натренированный пес всегда возьмет след! Но даже он не поможет найти нужную информацию в MySQL. Сегодня мы рассмотрим, как происходит поиск базе PHP. И как в этом деле обойтись без друга человека.
Как искать?
В одном из прошлых уроков мы рассматривали вывод данных в MySQL. Я рассказал вам, что для этого используются запросы SQL. Точнее, только одна команда – SELECT. Но в том раз я кое о чем умолчал: ее можно использовать не только для выборки данных и сортировки, но и для поиска.
Чтобы найти конкретную строку, отвечающую заданному условию, применяется оператор where. Для демонстрации всех примеров предлагаю перейти в phpMyAdmin.
Предположим, что нужно осуществить с помощью PHP поиск в базе MySQL. Нам надо найти строку, в которой значение столбца Name равно Aruba. Чтобы «отсеять» эту строку из всей таблицы, следует составить правильный запрос.
Вспоминаем все вышесказанное и принимаемся за дело. Первоначально разбираемся с условиями, которым должна соответствовать найденная строка. И со столбцами, значение которых должен вернуть запрос.
Онлайн курс «PHP-разработчик»
Изучите курс и создайте полноценный проект — облачное хранилище файлов
С нуля освоите язык программирования PHP, структурируете имеющиеся знания, а эксперты помогут разобраться с трудными для понимания темами, попрактикуетесь на реальных задачах. Напишете первый проект для портфолио.
Сказано, что в искомой строке значение столбца Name должно быть равно указанному. Это условие мы пропишем после оператора where. Все ли данные из этой строки нужно отображать? Предположим, что да:
Пишем поиск по сайту на PHP и MySQL
Сегодня мы напишем собственный поиск по сайту с использованием PHP и MySQL. Первым делом рассмотрим краткий алгоритм.
Пользователь выполняет POST запрос из формы поиска, этот запрос передается специальному скрипту-обработчику, который должен обработать поисковый запрос пользователя и возвратить результат.
Сначала скрипт должен обработать должным образом запрос пользователя для обеспечения безопасности, затем выполняется запрос к базе данных, который возвращает в ассоциативном массиве результаты, которые должны будут выводиться на экран. Итак, приступим.
Для начала создадим форму поиска на нужной нам странице:
Эта форма и будет отправлять сам поисковый запрос скрипту search.php. Теперь создадим сам скрипт-обработчик.
if (!mysql_select_db(DB_NAME)) < exit('Cannot select database'); >mysql_query('SET NAMES utf8'); function search ($query) < $query = trim($query); $query = mysql_real_escape_string($query); $query = htmlspecialchars($query); if (!empty($query)) < if (strlen($query) < 3) < $text = 'Слишком короткий поисковый запрос.
'; > else if (strlen($query) > 128) < $text = 'Слишком длинный поисковый запрос.
'; > else < $q = "SELECT `page_id`, `title`, `desc`, `title_link`, `category`, `uniq_id` FROM `table_name` WHERE `text` LIKE '%$query%' OR `title` LIKE '%$query%' OR `meta_k` LIKE '%$query%' OR `meta_d` LIKE '%$query%'"; $result = mysql_query($q); if (mysql_affected_rows() >0) < $row = mysql_fetch_assoc($result); $num = mysql_num_rows($result); $text = 'По запросу '.$query.' найдено совпадений: '.$num.'
'; do < // Делаем запрос, получающий ссылки на статьи $q1 = "SELECT `link` FROM `table_name` WHERE `uniq_id` = '$row[page_id]'"; $result1 = mysql_query($q1); if (mysql_affected_rows() >0) < $row1 = mysql_fetch_assoc($result1); >$text .= ' href="'.$row1['link'].'/'.$row['category'].'/'.$row['uniq_id'].'" title="'.$row['title_link'].'">'.$row['title'].'
'.$row['desc'].'
'; > while ($row = mysql_fetch_assoc($result)); > else < $text = 'По вашему запросу ничего не найдено.
'; > > > else < $text = 'Задан пустой поисковый запрос.
'; > return $text; > ?>
Естественно, данные таблиц БД нужно задать собственные. Рассмотрим, что делает эта функция. Первые 4 строчки обрабатывают запрос, чтобы он стал безопасным для базы. Такую обработку нужно делать обязательно, т. к. любая форма на Вашем сайте — это потенциальная уязвимость для злоумышленников.
Затем идет проверка, не пустой ли запрос. Если запрос пустой, то возвращаем соответствующее сообщение пользователю. Если запрос не пустой, проверяем его на размер.
Если поисковый запрос имеет длину менее 3 или более 128 символов, также выводим соответствующие сообщения пользователю. Иначе, выполняем запрос к базе данных, который делает выборку идентификатора страницы, ее заголовка, описания, описания ссылки, категорию, если она есть и идентификатор самой статьи, в которой найдены совпадения нужных нам полей с поисковым запросом.
В данном случае мы делаем сравнение с текстом статьи, ее заголовком, ключевыми словами и описанием. Если ничего не найдено, выводим пользователю сообщение об этом. Если запрос возвратил хотя бы одну запись, выполняем в цикле еще один запрос, который делает выборку из таблицы со страницами ссылку на страницу, на которой находится статья.
Если у Вас все статьи на одной странице, вы можете опустить этот шаг. После выполнения запроса при каждой итерации цикла в переменную $text Дозаписываем одну найденную статью.
После завершения цикла, возвращаем переменную $text , Которая и будет выводиться на нашей странице пользователю.
Теперь осталось на этой же странице search.php сделать вызов этой функции и вывести ее результат пользователю.
Также вы можете упростить скрипт поиска по Вашему усмотрению. Желательно создать стиль в таблице css для выводимой информации, чтобы выводимая информация смотрелась более красиво и читабельно. Все замечания вопросы по скрипту можете задавать в комментариях.
PHP MySQL search database and display results
Hi friends, in this tutorial you will learn how to perform a PHP MySQL search database and display results in a step-by-step process from scratch. We must know that database searching is very useful in any kind of application or in any dynamic website. Therefore, we can do this with the help of a PHP script and get the desired results based on the search input from HTML forms.
Steps to perform PHP MySQL search database and display results
Step 1:- Create a database in PHP Myadmin as shown in the below screenshot.
Step 2:- Create a table in the database as shown in the below screenshot.
Step 3:- Insert data in the table.
In this step, we will insert some data with the help of an SQL query so that we can search from these data and show the results later as shown below
Query example for inserting data:- INSERT INTOemployee_info
(id
,name
,phone_no
,age
,department
,created_at
,updated_at
) VALUES (NULL, 'ABC', '1234567891', '25', 'IT', current_timestamp(), '0000-00-00 00:00:00.000000');
Now, you can see the inserted data as shown below
Step 4:- Create a PHP file and Make an HTML form
In this step, we will create an HTML form with a search element so that we can enter the search input as shown below
Step 5:- Create a PHP file and establish the database connection as shown below
coonnect_test_db.php:-
setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); //echo 'connected'; > catch(PDOException $e) < echo '
'.$e->getMessage(); > ?>
Step 6:- Write a PHP script based on the search input.
prepare("select * from employee_info where department like '%$search%' or name like '%$search%'"); $stmt->execute(); $employee_details = $stmt->fetchAll(PDO::FETCH_ASSOC); > else < $searchErr = "Please enter the information"; >> ?>
Below are the two examples of searching data from the database
- If the search input is matched with the column value and the column has the single value then it will return the single row as shown in the below screenshot.
- If the search input is matched with the column value and the column has more than one value then it will return multiple rows as shown in the below screenshot.
Complete Code:- phpsearch.php
prepare("select * from employee_info where department like '%$search%' or name like '%$search%'"); $stmt->execute(); $employee_details = $stmt->fetchAll(PDO::FETCH_ASSOC); //print_r($employee_details); > else < $searchErr = "Please enter the information"; >> ?> .container
Search Result
No data found'; > else< foreach($employee_details as $key=>$value) < ?> # Employee Name Phone No Age Department > ?>