Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
3 / 3 / 0
Регистрация: 24.02.2017
Сообщений: 140

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

26.02.2017, 10:03. Показов 1953. Ответов 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
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru