Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL] Wyszukiwanie pełnotekstowe?
Forum PHP.pl > Forum > Przedszkole
xajart
Witam. 

Siedzę już od ponad 3 godzin i grzebię w tym necie w poszukiwniu jak zrobić by w bazie danych wyszukiwać zadanych fragmentów tekstu (przez wyszukiwarkę).

Wyczytałem o przeszukiwaniu pełnotekstowym za pomocą MATCH AGAINST, nawet dokumentacje do tego znalazłem na Fultext search ale szczerze powiedziawszy dalej kompletnie nie wiem o co z tym chodzi. Pytanie sformułować jest nie problem tylko nie wiem co mam zrobić by FULLTEXT dodać do tablicy w MySQL. Piszą tam że od wersji 4 jest to standardowo dostępne, i mimo ze mam nową wersję MySQL to jakoś nie mogę tego nigdzie znaleźć. 

Poza tym wyczytałem też gdzieś, że są jakieś problemy z używaniem tego odnośnie ilości trafień itp (że nie można tych kryteriów zmienić).

Może napisze do czego jest mi to potrzebne: mam zrobioną wyszukiwarkę produktów, w której użytkownik poza wpisaną frazą (tekstem) wybiera 3 opcje z list rozwijalnych, dotego 2 opcje są ukryte w formularzu - okreslajace rodzaj i typ produktu. Chce zbudować wyszukiwarkę za pomocą której poprzez odpowiednio sformułowane zapytanie do BD uzyskam odpowiednie wyniki. Wiem że można używac MATCH AGAINST kilka razy w zapytaniu odnośnie różnych kolumn i tekstów wyszukiwania. Problem jest w tym, że nie wiem jak się za to zabrać, a angielki u mnie jest na słabym poziomie.

Byłbym bardzo wdzięczny jak by mi to ktoś wytłumaczył. Bo mogę to rozwiązać pobierając odpowiednią ilość rekordów a potem kontrolujac je za pomocą eregów czy zawiera odpowiedni wpis jak tak to wyświetl. Ale to po pierwsze zajmie sporo kodu a po drugie skoro można to łatwiej rozwiązać to nie chce mi się na około tego kodu klepać.


potreb
Tutaj http://www.php.rk.edu.pl/w/p/pelnotekstowe-wyszukiwanie/ masz opisane mniej więcej o wyszukiwaniu pełnotekstowym. Używam sam wyszukiwania pełnotekstowego ale dla zawartości strony.
bigZbig
Polecam http://devzone.zend.com/article/1304
CyberDuck_
Sprobuj z LIKE , NP:
  1. $result = mysql_query("SELECT id, produkt FROM towary LIKE '%$fraza' ORDER BY data_dodania DESC");
  2. while(list($id, $login) = mysql_fetch_row($result)) {
  3. echo "$id - $produkt <br>";
  4. }

Przy czym znak % okreska z ktorej strony moze stac dowolny
ciag znakow. Czyli jesli masz powiedzmy w bazie 'kakao' i uzyjesz :
'%kao', 'ka%' to bedzie zawsze prawdziwe. Jesli dasz bez % to
wyszuka Ci konkretna fraze.
Riklaunim
Cytat(CyberDuck_ @ 30.09.2009, 16:23:08 ) *
Sprobuj z LIKE , NP:
  1. $result = mysql_query("SELECT id, produkt FROM towary LIKE '%$fraza' ORDER BY data_dodania DESC");
  2. while(list($id, $login) = mysql_fetch_row($result)) {
  3. echo "$id - $produkt <br>";
  4. }

Przy czym znak % okreska z ktorej strony moze stac dowolny
ciag znakow. Czyli jesli masz powiedzmy w bazie 'kakao' i uzyjesz :
'%kao', 'ka%' to bedzie zawsze prawdziwe. Jesli dasz bez % to
wyszuka Ci konkretna fraze.


LIKE nie jest wyszukiwaniem pełnotekstowym, ani nie skaluje się - przy dużej ilości rekordów będzie wykonywane bardzo długo.

Co do wyszukiwania w MySQL to można zastosować pełnotekstowego silnika dla tabel MyISAM, lecz lepszym rozwiązaniem będzie podpięcie Sphinxa - http://www.sphinxsearch.com/ - jeżeli ten sklep ma być jakimś większym i nastawionym na wysoką jakość winksmiley.jpg
xajart
Na dzisiaj chyba już sobie dam siana, bo z tym wyszukiwaniem pełnotekstowym mi to nie działa i od strony SQL też wywala błędy mimo że dodałem to FULLTEXT i robiłem dokładnie tak jak w opisie na stronce podanej przez potreb.

Jutro może poptarze co to jest ten Sphinx winksmiley.jpg - ale z tego co luknełem na stronkę - to mi się wydaje czy to jest na drupal'a questionmark.gif
CyberDuck_
Ile to jest dla Ciebie duzo ? 100 tys rekordow ? z baza 300 MB ?
Tyle to jest dla Ciebie duzo ? No to ja mam tyle i stosuje LIKE
i trwa chwilke. Wlasciwie to od razu pokazuja sie rekordy, ale
oczywiscie mozesz sobie doinstalowywac kupe skryptow zeby
cos osiagnac, a po przeniesieniu na inny serwer zobaczyc fige
admina, ktory sie w koncu zbuntuje biggrin.gif
xajart
Puki co zrobiłem to na LIKE, bo z tym przeszukiwaniem pełnotekstowym coś mi to nie działa i za dużo czasu mi zajmuje dochodzenie w czym tkwi problem, kiedyś może to rozgryze.

Dziękuje wszystkim za przydatne rady i pomoc w temacie, wdzięczny byłbym jeszcze jak by ktoś mógłby podać mi jakiś przykład z tym wyszukiwaniem pełnotekstowym, który bym mógł sobie sprawdzić czy pójdzie a jak nie to rozgryźć dlaczego to nie działa u mnie.

piotrooo89
a zapytam tak czysto teoretycznie ustawiłeś kolumnę w tabeli na wyszukiwane pełnotekstowe?
Riklaunim
Cytat(xajart @ 30.09.2009, 19:09:38 ) *
Jutro może poptarze co to jest ten Sphinx winksmiley.jpg - ale z tego co luknełem na stronkę - to mi się wydaje czy to jest na drupal'a questionmark.gif

Sphinx to "aplikacja" działająca obok baz danych służąca właśnie do indeksowania zawartości tabel i wyszukiwania w zaindeksowanych danych, czy też wykonywania złożonych zapytań winksmiley.jpg Niestety na hostingach współdzielonych generalnie nie ma dostępu do tego narzędzia.

Cytat(CyberDuck_ @ 30.09.2009, 19:11:38 ) *
Ile to jest dla Ciebie duzo ? 100 tys rekordow ? z baza 300 MB ?
Tyle to jest dla Ciebie duzo ? No to ja mam tyle i stosuje LIKE
i trwa chwilke. Wlasciwie to od razu pokazuja sie rekordy, ale
oczywiscie mozesz sobie doinstalowywac kupe skryptow zeby
cos osiagnac, a po przeniesieniu na inny serwer zobaczyc fige
admina, ktory sie w koncu zbuntuje biggrin.gif

A wiesz co to Sphinx? Bo skryptem to on nie jest. Pytanie też jak stosujesz to LIKE - czy z czy bez wildcardu na początku wyrażenia (a ma to spore znaczenie na wydajność zapytania) i jak bardzo baza jest obciążona pozostałym ruchem? W przypadku wyszukiwarki produktów - w sklepie internetowym - musi działać to szybko i efektywnie przy częstym użytkowaniu winksmiley.jpg
A Sphinxa już stosowałem np. w GL, gdzie jak masz np. 1500 osób online to "wyszukiwanie" z LIKE + parę innych warunków by nie przeszło (a postów, czy użytkowników jest w bazie bardzo dużo)
bigZbig
~Riklaunim - na podstawie tego co przeczytałem w artykule Pełnotekstowe wyszukiwanie w PHP z wykorzystaniem Sphinxa nie mogę się z Tobą w pełni zgodzić. Okazuje się, że sphinxa można użyć oczywiście w wersji binarne wymagającej praw root-a, ale mamy też do dyspozycji php-ową bibliotekę realizującą te same zadania co binarne rozszerzenie. Zamierzam to wkrótce przetestować.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.