Модераторы: skyboy, MoLeX, Aliance, ksnk
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> скрипт поиска 
:(
    Опции темы
fakeman
Дата 16.7.2009, 12:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 137
Регистрация: 5.5.2009

Репутация: нет
Всего: нет



Подскажите алгоритм грамотного поиска по сайту. Искать как и по самому тексту новости так и по названию новости.
Есть такой запрос
Код

$result = mysql_query("SELECT * FROM news WHERE MATCH(title,text) AGAINST('$search')");

но он выдаёт ошибку 
Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in Z:\home\localhost\www\phpsite\search\search_view.php on line 21

если в запросе в MATCH тока 1 поле то работает исправно, в чём может быть проблема ? 
PM MAIL   Вверх
Ипатьев
Дата 16.7.2009, 12:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2232
Регистрация: 5.7.2009

Репутация: 28
Всего: 37



для начала надо вывести mysql_error()
поскольку то что у тебя написано, выдает совсем не запрос
PM MAIL   Вверх
patap
Дата 16.7.2009, 12:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 893
Регистрация: 7.5.2005
Где: Украина, Зп

Репутация: 26
Всего: 40



я помню заюзал гугловский поиск по сайту:
вот код

Код

<?php
  class GoogleSearchParser {
    private $parseFeed;
    private $google = array();
    var $a;
    
    public function GoogleSearchParser($word) {
      $word = urlencode(str_replace(' ', '+', $word));
      $this->parseFeed = & file_get_contents('http://www.google.com.ua/search?q=site%3Ayourdomain.com+'.$word);  // тут вместо yourdomain.com свой домен
    }
    
    public function ParseFeed() {
      if ($this->parseFeed) {
        preg_match_all('#(?:<h3 class=r><a href.*?>)(.*?)(?:</a>)#', $this->parseFeed, $title);
        $length = count($title[1]);

        preg_match_all('#(?:<div class="s">)(.*?)(?:</div>)#', $this->parseFeed, $description);
        $dBuffer = array();
        for ($i = 0; $i < $length; $i++) {
          $dBuffer[] = (preg_match_all('#(.*?)(?:<cite>.*?</span>)#', $description[1][$i], $tempRes)) ? $tempRes[1][0] : $description[1][$i];
        }
        
        preg_match_all('#(?:class=r><a href=")((?:ftp|https?)://(?:(?:[\w\-]+)\.(?:[\w]{2,4}))(?:(?:/?(?:[\w\-]+(?:\.[\w]{1,4})?)?)+)(?:\?)?(?:(?:(?:[\w]+(?:\[\])?(?:\=[\w]+(?:=+)?\&?)?)+)?)\#?(?:[\w\-]+)?)#', $this->parseFeed, $link);
        
        for ($i = 0; $i < $length; $i++) {
          $this->google[] = array('link' => $link[1][$i], 'title' => $title[1][$i], 'description' => $description[1][$i]);
        }
        return $this->google;
      }
    }
  }
  
  $google = new GoogleSearchParser($_POST['word']);
  $res = $google->ParseFeed();
  
  print_r($res);  
?>
<br /><br />
<form action="search.php" method="post">
<input type="text" name="word" size="60">
<input type="submit" value="Search">
</form>


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

запусти скрипт и погляди исходный код страницы

Это сообщение отредактировал(а) patap - 16.7.2009, 12:57


--------------------
На боку кобура болталась, сзади шашка отцовская звякала. 
Впереди меня все хохотало, а позади все плакало (с)
PM MAIL ICQ   Вверх
bars80080
Дата 16.7.2009, 14:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прапор творюет
****
Награды: 1



Профиль
Группа: Завсегдатай
Сообщений: 12022
Регистрация: 5.12.2007
Где: Königsberg

Репутация: 71
Всего: 315



Цитата(fakeman @  16.7.2009,  12:42 Найти цитируемый пост)
MATCH(title,text)

text - служебное слово, обрамляйте все имена полей обратными апострофами`
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "PHP"
Aliance
IZ@TOP
skyboy
SamDark
MoLeX

Новичкам:

  • PHP редакторы собираются и обсуждаются здесь
  • Электронные книги по PHP, документацию можно найти здесь
  • Интерпретатор PHP, полную документацию можно скачать на PHP.NET

Важно:

  • Не брезгуйте пользоваться тегами [code=php]КОД[/code] для повышения читабельности текста/кода.
  • Перед созданием новой темы воспользуйтесь поиском и загляните в FAQ
  • Действия модераторов можно обсудить здесь

Внимание:

  • Темы "ищу скрипт", "подскажите скрипт" и т.п. будут переноситься в форум "Web-технологии"
  • Темы с именами: "Срочно", "помогите", "не знаю как делать" будут УДАЛЯТЬСЯ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, IZ@TOP, skyboy, SamDark, MoLeX, awers.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0728 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.