С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 05.04.2015
Сообщений: 24

Поисковый запрос на сайте из базы данных

29.08.2019, 11:52. Показов 803. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Создала на сайте поисковую строку и пытаюсь по слову, введенному в эту строку, найти статью из моей базы данных. Независимо от того, что ввожу (ничего, левое слово или слово, которое н=точно есть в названии) выводит белый экран.
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
<?php 
$mysqli = new mysqli('localhost', 'root', '', 'rel1');
 
 
if ($mysqli->connect_error) {
 die('Connect Error: ' . $mysqli->connect_error);
}
 
function search ($query) 
{ 
$mysqli = new mysqli('localhost', 'root', '', 'rel1');
    $query = trim($query); // удаление пробелов с начала и конца
    $query = mysqli_real_escape_string( $mysqli, $query); 
    $query = htmlspecialchars($query); //преобразование спец символов
 
    if (!empty($query)) 
    { 
        if (strlen($query) < 3) {
            $text = '<p>Слишком короткий поисковый запрос.</p>';} 
        else { if (strlen($query) > 128) {
            $text = '<p>Слишком длинный поисковый запрос.</p>';} 
            else { 
            $q = "SELECT name FROM document
                  WHERE document.name LIKE %$query%";
                  
 
            $result = mysqli_query($mysqli, $q)or die(mysql_error());
 
 
            if (mysqli_affected_rows() > 0) { 
                $row = mysqli_fetch_assoc($result); 
                $num = mysqli_num_rows($result);
 
                $text = '<p>По запросу <b>'.$query.'</b> найдено совпадений: '.$num.'</p>';
 
                do {
                    // Делаем запрос, получающий ссылки на статьи
                    $q1 = "SELECT document.link FROM document WHERE `id_doc` = '$row[id_doc]'";
                    $result1 = mysqli_query($q1);
 
                    if (mysqli_affected_rows() > 0) {
                        $row1 = mysqli_fetch_assoc($result1);
                    }
 
                    $text .= '<p><a href="'.$q1.'"> '.$row['name_doc'].' </a></p>
                    <p>'.$row['pdf_doc'].'</p>';
 
                } while ($row = mysqli_fetch_assoc($result)); 
            } else {
                $text = '<p>По вашему запросу ничего не найдено.</p>';
        }}}
        
     }
    else $text='<p> Задан пустой запрос.</p>';
    return $text; 
}
 
echo "<! -- fuction end description -->"; 
if (!empty($_POST['query'])) { 
    $search_result = search ($_POST['query']); 
    echo $search_result; 
}
?>
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.08.2019, 11:52
Ответы с готовыми решениями:

Есть ли поисковый спам на сайте?
Хотел добавить сайт www.bcmoscow.ru в яндекс и рамблер. Но не тут то было: Яндекс: &quot;Адрес не был внесен в базу Яндекса, так как...

Контекстный и поисковый Директ на одном сайте
Есть сайт с размещенной контекстной рекламой Директа. Сделал поиск по сайту, соответственно, в поиск хотелось бы прикрутить...

Откуда Яндекс обнаружил поисковый спам на сайте?
Уважаемые коллеги, прошу подсказать кто разбирается в теме. Часть разделов сайта пропали из поиска. Отписал в службу поддержки (дважды)....

2
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
29.08.2019, 13:33
Цитата Сообщение от MashaZav Посмотреть сообщение
выводит белый экран
включите отображение ошибок

Скорее всего у Вас поле name текстовое. Тогда заверните переменную в одинарные кавычки: WHERE document.name LIKE '%$query%'"

Функция mysqli_affected_rows возвращает число затронутых прошлой операцией рядов последним INSERT, UPDATE, DELETE. Причём здесь SELECT?

Подключение к БД дорогая операция. Вы уже получили объект подключения к БД ($mysqli), дальше работайте с ним во всех остальных запросах к БД.
0
Заблокирован
03.09.2019, 20:58
Цитата Сообщение от MashaZav Посмотреть сообщение
function search ($query)
{
$mysqli = new mysqli('localhost', 'root', '', 'rel1');
Вы дублируете в своей функции подключение к базе. Слышали про глобальные переменные?
PHP
1
2
3
function search ($query) 
{
 $mysqli  = $GLOBALS["mysqli"];
Это оптимизирует Ваш код.
А по поводу функции - то это какая то муть. В отображении результата поиска вкладываете еще какой-то запрос. Разве в таблице нельзя хранить и название и ссылку на статью? Если ссылку нельзя получить из названия или айди, что обычно и делается. С такими поисками можно подвесить сайт на раз-два.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.09.2019, 20:58
Помогаю со студенческими работами здесь

Базы данных на сайте
Если честно, даже не знаю с чего начать. Может моя проблема кому-то покажется бредом, но мне именно это и нужно. Нужно создать две...

Поисковый Запрос
Всем привет. Буду честен. В упор забыл как сравнить две даты в поисковом запросе. Query = {FORM = &quot;task&quot; &amp; Date= }&amp;...

Поисковый запрос
Имеется test.csv Example,luna,x2,1.0 Primer,zoloto,x8,1.2 Test1,serebro,o9,1.1 Test2,metall,x2,1 Необходимо сделать...

Поисковый запрос
Здравствуйте. Есть такая вот строчка: ShellExecuteA(NULL, &quot;open&quot;, &quot;http://google.ru&quot;, NULL, NULL, SW_SHOWNORMAL); эта строчка открывает в...

Поисковый запрос. API
Здравствуйте. Не давно появилась необходимость парсинга сайтов по определенному запросу. Перерыл весь google api, но ничего годного не...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru