Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
52 / 3 / 4
Регистрация: 27.02.2016
Сообщений: 277

Поиск в sql

25.06.2017, 18:46. Показов 2202. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет. Подскажите решение.

Есть запрос:
PHP
1
$sql = mysql_query ("SELECT * FROM  products WHERE keywords like '%$keywords%'");
В $keywords допустим содержится фраза "удаляет загрязнения"
В результате будут выводится поля, где есть точное соответствие и последовательность фразы, но если будет после с текстом
"Данное средство удаляет самые стойкие загрязнения" то выводиться оно не будет.

Какой метод использовать?

И еще подскажите, как сделать так, чтобы поиск был по совпадению первых 3-4 букв в запросе, если так можно выразиться, или по корню слова.
Т.е. если ввести слово "профессиональный", то выводиться будет поле, где есть слово "профессиональному", "профессиональные".

Заранее спасибо.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.06.2017, 18:46
Ответы с готовыми решениями:

Поиск по БД SQL
Есть датагривью с таблицеq, есть текстбокс. Подскажите, как можно реализовать поиск по столбцу Id типа int, чтоб я вводил id в текстбокс, а...

Поиск ms sql
комрады, создаю на C# приложение для БД на ms sql server, Через запрос вида Where LIKE ' А%' (вывод с начальным по А) удаётся выполнять. А...

SQL поиск
Всем привет. Как произвети поиск по БД, используя ADOQuery, SQL-запросы. На форме есть текстовое поле для ввода текста поиска, и...

4
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
25.06.2017, 19:04
PHP
1
2
3
4
5
$s = 'удаляет загрязнения';
$m = explode(' ',$s);
$l = array();
foreach ($m as $s) $l[] = '`keywords` like \'%'.$s.'%\'';
$sql = mysql_query ("SELECT * FROM  products WHERE ".implode(' AND ',$l));
Добавлено через 6 минут
Возможно существует сервис, определяющий корень слова по слову
Можно попробовать установить сфинкс или яндекс.сервер
0
52 / 3 / 4
Регистрация: 27.02.2016
Сообщений: 277
25.06.2017, 19:27  [ТС]
Отлично работает. У меня еще подсветка ключевых фраз идет таким запросом:
PHP
1
preg_replace('/('.$keywords.')/iu','<b style="color:red;">\1</b>',$result['opisanie']);
Здесь идет подсветка красным только если запрос совпадает точно, а если слова в разных местах текста то нет.
Как подсветить оба слова из запроса, если они врозь?
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
25.06.2017, 19:54
Лучший ответ Сообщение было отмечено samvel4000 как решение

Решение

PHP
1
2
3
4
5
6
7
8
<?php
$s = 'удаляет загрязнения';
$s = str_replace(' ','|',$s);
function podsvetit($q) {
        return '<b style="color:red;">'.$q[0].'</b>';
}
$t = 'Данное средство удаляет самые стойкие загрязнения. Данное средство удаляет самые стойкие загрязнения.';
echo $t = preg_replace_callback('/('.$s.')/','podsvetit',$t);
1
52 / 3 / 4
Регистрация: 27.02.2016
Сообщений: 277
25.06.2017, 19:55  [ТС]
Как часы. Спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.06.2017, 19:55
Помогаю со студенческими работами здесь

Поиск по БД SQL
Доброго! Имеем таблицу в бд Если строим поиск так Form1-&gt;ADOQuery1-&gt;Close(); Form1-&gt;ADOQuery1-&gt;SQL-&gt;Clear(); ...

Поиск sql
Цель вывести из базы информацию где найденно первые несколько символов из поле. пишу mysql_query(&quot;SELECT `title` FROM `obev` WHERE...

поиск по БД PHP+sql
Доброго времени суток! у меня такой вопрос. Есть код для поиска номера телефона по базе. Он ищет если забиваешь номер без пробелов. ...

Поиск SQL серверов
Подобный вопрос уже был. Ответы мне не очень понравились, поэтому задаю еще раз но с уточнением, может кто-нибудь сможет помочь... ...

Поиск с использованием SQL
Помогите пожалуйста, не могу додумать как организовать поиск по нескольким полям в бд. procedure TForm3.Edit1KeyUp(Sender: TObject;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru