3 / 3 / 0
Регистрация: 24.02.2017
Сообщений: 140

Поиск слов в базе данных с использованием специальных символов

26.02.2017, 10:03. Показов 1989. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уважаемые программисты, добрый день! Помогите пожалуйста решить задачу по поиску слов в базе данных MySQLс использованием специальных символов.
Пример:
'*' - заменяет любую комбинацию символов (вводим в форму "чай*" результат поиска "чайник" "чайка" "Чайковский"
'?' - заменяет один символ (вводим "бар?" результат "бары" "баре" "бару", но не "бар" и не "барный").

Заранее благодарю
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.02.2017, 10:03
Ответы с готовыми решениями:

Поиск по базе данных с использованием Java
Есть БД с одной таблицей, и созданы сервлеты для вывода данных, изменения, удаления добавления. Но нужно еще добавить функцию поиска...

Динамический поиск по базе данных, с использованием ADOQuery и DBGrid
Есть на форме DBGrid и Edit, так вот, когда мы вводим в Edit символы, тут же начинается поиск и в DBGrid-е отображаются результаты. Т. е....

Очистка вводимых пользователем данных от специальных символов
Коллеги! Есть задача выполнить фильтрацию вводимых данных от спецсимволов, таких как ! @ # $ % ^ & ( ) _ - = + { } ' ; ` ~ * ? и...

12
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
26.02.2017, 10:11
Так есть же оператор: https://dev.mysql.com/doc/refm... egexp.html
0
3 / 3 / 0
Регистрация: 24.02.2017
Сообщений: 140
26.02.2017, 10:13  [ТС]
А вы не могли бы написать скрипт (пример запроса к MySQL)?
0
119 / 116 / 63
Регистрация: 16.09.2016
Сообщений: 354
26.02.2017, 10:17
LIKE
0
3 / 3 / 0
Регистрация: 24.02.2017
Сообщений: 140
26.02.2017, 10:26  [ТС]
Вот мой код (но он не работает):

PHP
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
<?php
require_once "function.php";
if(isset($_POST["search"]) && !empty($_POST["words"]))
{
    $str = $_POST["words"];
    if(strpos($str, "*"))
    {
        $res = str_replace("*", "", $str);
        $select = $db->query("SELECT `title` FROM `test` WHERE `title` LIKE '$res%'") or die(mysqli_connect_error());
        while($row = $select->fetch_array())
        {
            $search = $row['title'];
    
        }
    }
    elseif(strpos($str, "?"))
    {
        $res = str_replace("?", "", $str);
        $select = $db->query("SELECT `title` FROM `test` WHERE `title` LIKE '$res_'") or die(mysqli_connect_error());
        while($row = $select->fetch_array())
        {
            $search = $row['title'];
    
        }
    }
}
?>
0
119 / 116 / 63
Регистрация: 16.09.2016
Сообщений: 354
26.02.2017, 10:48
Замените $res в запросах на {$res} или ".$res.", должно получиться типа:
PHP
1
$select = $db->query("SELECT `title` FROM `test` WHERE `title` LIKE '".$res."_'") or die(mysqli_connect_error());
0
3 / 3 / 0
Регистрация: 24.02.2017
Сообщений: 140
26.02.2017, 10:54  [ТС]
svs171, нет, не работает. Программа не выдает ошибку, но и результат поиска не выводит
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
26.02.2017, 11:08
Цитата Сообщение от Серега_123 Посмотреть сообщение
$select = $db->query("SELECT `title` FROM `test` WHERE `title` LIKE '$res_'") or die(mysqli_connect_error());
$db - это объект какого класса? mysqli? Если да, то почему ошибка запроса выводится функцией, предназначенной для вывода ошибки установления соединения? А прои защиту от инъекций говорить не буду.
PHP
1
$select = $db->query("SELECT `title` FROM `test` WHERE `title` LIKE '$res%'") or die(mysqli->error);
0
3 / 3 / 0
Регистрация: 24.02.2017
Сообщений: 140
26.02.2017, 11:13  [ТС]
Jewbacabra, если or die(mysqli_connect_error()); заменить на die(mysqli->error);
то программа вообще не работает
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
26.02.2017, 11:16

Не по теме:

Цитата Сообщение от Серега_123 Посмотреть сообщение
вообще не работает
Программа может не работать, вообще не работать, аналогия с запрещено, строго запрещено, категорически запрещено


Сообщения об ошибках включать надо, и код не тупо копировать, а думать при этом.
PHP
1
die($db->error)
0
3 / 3 / 0
Регистрация: 24.02.2017
Сообщений: 140
26.02.2017, 11:28  [ТС]
Jewbacabra, спасибо за подсказку.
Но к сожалению программа все равно не ищет
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
26.02.2017, 11:54
http://phpfaq.ru/debug
0
3 / 3 / 0
Регистрация: 24.02.2017
Сообщений: 140
27.02.2017, 04:42  [ТС]
Jewbacabra, я вытащил весь текст из поля title в виде массива, разбил его. А как найти слово то???
Есть массив, например array = "чай чайник чайка"
как в этом массиве найти слово по его корню?

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
if(isset($_POST["search"]) && !empty($_POST["words"]))
{
    $str = $_POST["words"];
    if(strpos($str, "*"))
    {
        $res = str_replace("*", "", $str);
        $select = $db->query("SELECT * FROM `test`") or die($db->error);
        $row = $select->fetch_row();
        $search = $row[0];
        $list = explode(",", $search);
        
    }
}
Добавлено через 13 часов 54 минуты
Jewbacabra, Люди, помогите пожалуйста!

Вот мой код (он не работает, но должен искать слова в таблице с одним текстовым полем):

PHP
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
require_once "function.php";
if(isset($_POST["search"]) && !empty($_POST["words"]))
{
    $str = $_POST["words"];
    if(strpos($str, "*"))
    {
        $res = str_replace("*", "", $str);
        $select = $db->query("SELECT * FROM `test` WHERE MATCH (title) AGAINST ('$res%')") or die($db->error);
        while($row = $select->fetch_row())
        {
            $search = $row[0];
            $list = $saerch;
        
        }
}
    elseif(strpos($str, "?"))
    {
        $res = str_replace("?", "", $str);
        $select = $db->query("SELECT * FROM `test` WHERE MATCH (title) AGAINST ('$res%')") or die($db->error);
        while($row = $select->fetch_row())
        {
            $search = $row[0];
            $list = $saerch;
            
        
        }
}
}
 
for($i = 0; $i<count($list); $i++)
{
echo $list[$i];
}
?>
вообще ничего не происходит.
----------------------------------------------------------------------------------------------------------------------
Если написать такой код:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
require_once "function.php";
if(isset($_POST["search"]) && !empty($_POST["words"]))
{
    $str = $_POST["words"];
    if(strpos($str, "*"))
    {
        $res = str_replace("*", "", $str);
$select = $db->query("SELECT * FROM `test`") or die($db->error);
        $row = $select->fetch_row();
        $search = $row[0];
        $list = explode(",", $search);
}
 
print_r($list);
?>
то выводит такой вот массив: Array ( [0] =>газ газовый газированный газы чай чайник чайка баннер баннеру баннера баннерный )

----------------------------------------------------------------------------------------------------------------------------
А вот база данных:

SQL
1
2
3
4
5
6
7
8
9
10
11
CREATE TABLE IF NOT EXISTS `test` (
  `title` text NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8 DELAY_KEY_WRITE=1;
 
 
 
Dumping DATA FOR TABLE `test`
--
 
INSERT INTO `test` (`title`) VALUES
('газ газовый газированный газы\nчай чайник чайка\nбаннер баннеру баннера баннерный');
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.02.2017, 04:42
Помогаю со студенческими работами здесь

Дана строка текста, состоящая из слов. Слова отделяются друг от друга одним из специальных символов, которые описываются во множестве [‘-’, ‘*’, ‘/
Дана строка текста, состоящая из слов. Слова отделяются друг от друга одним из специальных символов, которые описываются во множестве ....

Поиск по базе с использованием нескольких текстбоксов
Столкнулся с такой проблемой... Необходим поиск по базе с использованием нескольких текстбоксов... но смог реализовать только в варианте...

Генератор специальных функций (синуса, пилы на базе ШИМ)
Мне нужно создать генератор специальных функций: пилообразный, синусоидальный сигналы (на основе ШИМ). При этом отсчеты сигналов за...

UML - Диаграмма классов (с использованием данных для длительного хранения в реляционной базе данных)
Как сделать диаграмму основных классов системы (как минимум привлечь классы, связанные с использованием данных для длительного хранения в...

Замена специальных символов
Нужно оставить только буквы,цифры,пробелы. Использую этот код $title = preg_replace (&quot;//&quot;,&quot;&quot;,$title); Но если...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru