ajax example

Пишем поиск по сайту на 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 символов, также выводим соответствующие сообщения пользователю. Иначе, выполняем запрос к базе данных, который делает выборку идентификатора страницы, ее заголовка, описания, описания ссылки, категорию, если она есть и идентификатор самой статьи, в которой найдены совпадения нужных нам полей с поисковым запросом.

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

Читайте также:  Contents php option 10

Если у Вас все статьи на одной странице, вы можете опустить этот шаг. После выполнения запроса при каждой итерации цикла в переменную $text Дозаписываем одну найденную статью.

После завершения цикла, возвращаем переменную $text , Которая и будет выводиться на нашей странице пользователю.

Теперь осталось на этой же странице search.php сделать вызов этой функции и вывести ее результат пользователю.

Также вы можете упростить скрипт поиска по Вашему усмотрению. Желательно создать стиль в таблице css для выводимой информации, чтобы выводимая информация смотрелась более красиво и читабельно. Все замечания вопросы по скрипту можете задавать в комментариях.

Источник

PHP MySQL search database and display results

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.

PHP MySQL search database and display results

Step 2:- Create a table in the database as shown in the below screenshot.

PHP MySQL search database and display results

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

PHP MySQL search database and display results

Query example for inserting data:- INSERT INTO employee_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

PHP MySQL search database and display results

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

PHP MySQL search database and display results

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.
Читайте также:  32 bit java machine

PHP MySQL search database and display results

  • 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.

PHP MySQL search database and display results

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 Employee Information::
Submit
*


Search Result


# Employee Name Phone No Age Department No data found'; > else< foreach($employee_details as $key=>$value) < ?> > ?>

Download the bootstrap CSS and js files from google and include the path of the files in the href attribute of link tag and src attribute of the script tag respectively.

CONCLUSION:- I hope this article will help you to understand the concept. If you have any doubt then please leave your comment below.

Источник

Простой поиск PHP MySQL

поиск php mysql

Уважаемые пользователи! Мы благодарим Вас за то, что Вам интересен нашен контент, поэтому с каждым днем хотим становиться все лучше и лучше!

В сегодняшнем уроке мы рассмотрим поиск php mysql​. Скриптов поиска огромное множество, некоторые используют базу данных, другие обходятся без нее, есть расширенные поиски с точной сортировкой. Мы же остановимся на обычном простом поиске, который ищет информацию по двум таблицам из базы данных MySQL.

Создаем базу данных search_lite, в ней две таблицы news — новости и vac — вакансии. Задаем привилегии: Логин — «root«, Пароль — «», Хост — «localhost«. Дамп таблицы news — новостей.

-- -- Table structure for table `news` -- CREATE TABLE IF NOT EXISTS `news` ( `id` int(2) NOT NULL, `title` varchar(255) NOT NULL, `text` text NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=cp1251;
-- -- Table structure for table `vac` -- CREATE TABLE IF NOT EXISTS `vac` ( `id` int(2) NOT NULL AUTO_INCREMENT, `title` varchar(255) NOT NULL, `text` text NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=cp1251 AUTO_INCREMENT=3 ;

Подключаемся к базе данных. Задаем условие по переменной $search, в которой поисковый запрос не введен, либо он меньше 4-х символов, а также проверяем на слеши и обрезаем переменную. Создаем два запроса, которые ищут в базе данных две таблицы news и vac по условию поиска по полю text. (Вы можете сами уже выбирать, сколько таблиц нужно будет для поиска. К примеру, у Вас будут таблицы lessons, materials, articles и т.п.. Также можете менять условия поиска, вместо поля text, можно выбрать поле title или другое поле.) Затем указываем сколько символов в тексте при выводе поиска в переменной $symbolls. Если же в таблицах news и vac по поиску ничего не найдено, выводим сообщение. Если же найдено, выводим данные из двух таблиц news и vac по заданному запросу поиска.


"; echo "

"; > else < echo "

"; $search = htmlspecialchars(stripslashes(trim($search))); $sql_news = mysql_query("SELECT id, title, text FROM news WHERE text LIKE '%$search%'"); $news = mysql_num_rows($sql_news); $sql_vac = mysql_query("SELECT id, title, text FROM vac WHERE text LIKE '%$search%'"); $vac = mysql_num_rows($sql_vac); $find = $search; $symbolls = '80'; if ($news==0 and $vac==0) echo "

"; else < /*Новости/news - таблица*/ for($i=1; $news = mysql_fetch_array($sql_news); $i++) < $search_text = $news['text']; $search_text = strip_tags($search_text, '
'); $search_txt_length = strlen ($search_text); $search_first_enter = strpos (strtolower($search_text), strtolower($find)); $pad_left = $search_first_enter - $symbolls; $pad_right = $search_first_enter + $symbolls + 5; if ($pad_right>$search_txt_length) $pad_right = $search_txt_length; if ($pad_left <0) $pad_left = '0'; $search_text = substr($search_text, $pad_left, $pad_right); $search_text = str_replace (strtolower($find), "

"; > /*Вакансии/vac - таблица*/ for($i=1; $vac = mysql_fetch_array($sql_vac); $i++) < $search_text = $vac['text']; $search_text = strip_tags($search_text, '
'); $search_txt_length = strlen ($search_text); $search_first_enter = strpos (strtolower($search_text), strtolower($find)); $pad_left = $search_first_enter - $symbolls; $pad_right = $search_first_enter + $symbolls + 5; if ($pad_right>$search_txt_length) $pad_right = $search_txt_length; if ($pad_left <0) $pad_left = '0'; $search_text = substr($search_text, $pad_left, $pad_right); $search_text = str_replace (strtolower($find), "

"; > > > > ?>

.search_name < color: black; font-size: 18px; >.search_questions < color: black; font-weight: bold; font-size: 15px; >.search_query < color: blue; font-style: Italic; >.search_error < color: red; font-size: 15px; >.search_input < border: 1px solid black; width: 500px; height: 30px; >.search_word < color: blue; >.search_title < font-size: 20px; color: blue; font-weight: bold; >.search_text < font-size: 15px; color: black; >.search_cat

Мы рассмотрели с Вами простой поиск php mysql, который ищет информацию из базы данных. По условию используются две таблицы, Вы можете настроить под себя любым удобным способом. Следующий урок будет посвящен аналогии простого поиска, только с расширенными возможностями.

Источник

Оцените статью