![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 141 Pomógł: 1 Dołączył: 2.12.2008 Ostrzeżenie: (0%) ![]() ![]() |
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ć. |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 141 Pomógł: 1 Dołączył: 2.12.2008 Ostrzeżenie: (0%) ![]() ![]() |
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 (IMG:style_emoticons/default/winksmiley.jpg) - ale z tego co luknełem na stronkę - to mi się wydaje czy to jest na drupal'a (IMG:style_emoticons/default/questionmark.gif) Ten post edytował xajart 30.09.2009, 18:11:54 |
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 640 Pomógł: 44 Dołączył: 8.02.2004 Ostrzeżenie: (0%) ![]() ![]() |
Jutro może poptarze co to jest ten Sphinx (IMG:style_emoticons/default/winksmiley.jpg) - ale z tego co luknełem na stronkę - to mi się wydaje czy to jest na drupal'a (IMG:style_emoticons/default/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ń (IMG:style_emoticons/default/winksmiley.jpg) Niestety na hostingach współdzielonych generalnie nie ma dostępu do tego narzędzia. 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 (IMG:style_emoticons/default/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 (IMG:style_emoticons/default/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) |
|
|
![]() ![]() |
![]() |
Aktualny czas: 13.10.2025 - 20:15 |