Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
252 / 8 / 0
Регистрация: 12.11.2009
Сообщений: 170

Не работает поиск. Где ошибка?

14.08.2010, 16:33. Показов 1366. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток всем.
3 день мучаюсь. Вот код поиска по базе. Дело в том, что выводит все из базы, а не искомую запись

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
64
65
66
67
68
69
<?php
    $table='products';
    $text_to_search=$_POST['s'];
    
 
    function search ()
    {  global $rows,$link,$table;
 
    /* Соединение, выбор БД */
 
    $rows=10;
 
    $link = mysql_connect ("localhost", "root", "") or die ("Ошибка соединения с базой");
    mysql_select_db ("medtehica") or die("Не найдена БД");
    mysql_query("SET NAMES 'cp1251';");
 
    $text_to_search=$_POST['s'];
 
    if ($id=mysql_query("SELECT id FROM $table WHERE name LIKE '%$text_to_search%' OR text LIKE '%$text_to_search%'"))
    {
    
    $count=0;
    while ($row=@mysql_fetch_assoc($id)) $count++;
 
    //подсчитываем количество страниц
    if ($count%10 != 0) $count = intval($count/$rows)+1; else $count = intval($count/$rows);
    if(isset($_GET['page'])) $page = $_GET['page']; else $page=1;
 
    // задаём позицию которая будет посылаться через гет запрос с параметром page
    $page1 = $page*$rows-$rows;
    $page2 = $page1 + $rows;
 
    // посылаем запрос по поиску ключевых слов в базе
    $res = mysql_query("SELECT * FROM $table  WHERE name LIKE '%$text_to_search%' OR text LIKE '%$text_to_search%' LIMIT $page1, $page2");
 
    while ($row=@mysql_fetch_array($res) and $i<$rows)
    {
    $i++;
    $a=($page-1)*$rows+$i;
 
    // выводим список
    echo $a.'. &nbsp;&nbsp; '.$row['name'].'<br />';
    }
 
    }
 
    else echo "Ничего не найдено $text_to_search";
 
    $i=0;
    $content .= '<br><center><form method="get"><input type="hidden" name="catalog" value="id"><input type="hidden" name="s" value="'.$_GET['s'].'" />';
    if(isset($_GET['page'])) $this_page=$_GET['page']; else $this_page=1;
    $i=$this_page-3;
    while ($i<=$this_page+1)
    {
    $i++;
    if($i>0)if($i<=$count)
    if($i!=$this_page) $content .= "<input type='submit' name='page' value='".$i."' />";
    else $content .= "&nbsp;&nbsp;".$i."&nbsp;&nbsp;";
    }
 
    $content .= "</center>";
    $content .= '</form></center>';
    echo $content;
 
    }
 
    if(isset($_GET['s'])) search();
    
    ?>

HTML5
1
2
3
4
    <form action="search.php" method="get">
    <input type="text" name="s" size="60" value=""><br>
    <input type="submit" name="submit" value="Искать">
    <input type="reset" name="reset" value="Очистить"></form>
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.08.2010, 16:33
Ответы с готовыми решениями:

В Мозиле работает, в IE не работает. Где здесь ошибка?
function loadResults(params) { document.getElementById('page-content').innerHTML = 'Loading &lt;img src=&quot;/images/spinner.gif ' ...

Живой поиск, где ошибка?
Делаю живой поиск, всё работает, но проблема в том, что не вставляется при клике текст с div в input. В jquery еще не силен, только учусь,...

Проверить где быстрее работает поиск в векторе или листе
Мне нужно проверить что быстрее работает поиск. Я наисала, но лист выдает всегда :0. Где я натупила? #include &lt;cstdlib&gt; ...

8
143 / 109 / 13
Регистрация: 13.02.2010
Сообщений: 522
15.08.2010, 12:50
а так не пробовали?
PHP
1
  $res = mysql_query("SELECT * FROM $table  WHERE name='$text_to_search' OR text='$text_to_search' LIMIT $page1, $page2");
0
 Аватар для romchiksoad
1957 / 796 / 89
Регистрация: 03.11.2009
Сообщений: 3,066
Записей в блоге: 2
15.08.2010, 19:40
lesha_firs, Ваш код подойдет только в том случае, если в тех полях храниться именно этот текст и никакого другого. Я так понял, что там есть другой текст по мимо передаваемого в запрос. Вам нужно использовать в запросах MATCH и AGAINST. Вот тут лежит ман по MySQL ( последняя версия ).
1
252 / 8 / 0
Регистрация: 12.11.2009
Сообщений: 170
15.08.2010, 23:15  [ТС]
Огромная благодарность всем кто отозвался. А romchiksoad особая за инфу. Все разобрался. Работает.
Вот только одна проблемка поиск чуствителен к регистру т.е. если я в базу пропишу "Форум" а искать буду "форум" он ничего не найдет. Как "отключить" чуствительность к регистру?
0
252 / 8 / 0
Регистрация: 12.11.2009
Сообщений: 170
16.08.2010, 16:54  [ТС]
Вот скриншот. Про код не совсем понял. Код это "Экспорт бд"?
Миниатюры
Не работает поиск. Где ошибка?  
0
 Аватар для romchiksoad
1957 / 796 / 89
Регистрация: 03.11.2009
Сообщений: 3,066
Записей в блоге: 2
16.08.2010, 17:03
Columb, так и думал Измените кодировку с cp1251_bin на cp1251_general_ci
1
252 / 8 / 0
Регистрация: 12.11.2009
Сообщений: 170
16.08.2010, 17:34  [ТС]
Все отлично работает! Огромное Вам благодарность.
0
 Аватар для vano793
11 / 11 / 1
Регистрация: 29.10.2009
Сообщений: 91
10.01.2011, 14:59
Здравствуйте. Мне подходит этот поиск для сайта но что то сам догнать не могу. Помогите мне плиз.
У меня таблица lessons в ней информация.
Вот скрин. Хочу что бы поиск брал и искал только в поле title (Допустим).
Выводил как поисковик. Получается поиск нужен для сайта.
0
252 / 8 / 0
Регистрация: 12.11.2009
Сообщений: 170
05.02.2011, 18:28  [ТС]
Цитата Сообщение от vano793 Посмотреть сообщение
Здравствуйте. Мне подходит этот поиск для сайта но что то сам догнать не могу. Помогите мне плиз.
У меня таблица lessons в ней информация.
Вложение 57846 Вот скрин. Хочу что бы поиск брал и искал только в поле title (Допустим).
Выводил как поисковик. Получается поиск нужен для сайта.
Берите полностью весь код, только найдете строки

SQL
1
mysql_query("SELECT * FROM $table  WHERE name LIKE '%$text_to_search%' OR text LIKE '%$text_to_search%' LIMIT $page1, $page2");
и перепишите их так

SQL
1
mysql_query("SELECT * FROM $table  WHERE title LIKE '%$text_to_search%'  LIMIT $page1, $page2");
Где то так) Должно работать)))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.02.2011, 18:28
Помогаю со студенческими работами здесь

не работает где ошибка?
#include&lt;iostream&gt; using namespace std; int main() { long i,s; for (int s=0; i = 0; i = 1.5; s=2.5; ++i; s=s+i) { ...

поиск максимума в двумерном массиве, где ошибка
// lab2_1.cpp: определяет точку входа для консольного приложения. // #include &quot;stdafx.h&quot; #include &lt;conio.h&gt; #include...

Проект не работает. Где ошибка?
Выдает ошибку &quot;unit1.pas(35,3) Fatal: Syntax error, &quot;IMPLEMENTATION&quot; expected but &quot;BEGIN&quot; found&quot; var s: real; Form1: TForm1; ...

Не работает программа, где ошибка?
Помогите исправить или дополнить программу, чтобы она отвечала на вопрос: &quot;Пересекаются ли две фигуры? (круг и ромб)&quot; program...

Код не работает где ошибка?
Вот код, должен вернуть результат обработки $sing_hash но ksort выдает ошибку 1 параметр array_push тоже самое.... Не могу найти ошибку...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru