![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 60 Pomógł: 0 Dołączył: 6.12.2010 Ostrzeżenie: (0%) ![]() ![]() |
Witam, mam problem z zapytaniem. Chciałbym jednym zapytaniem przeszukać 7 tabel, wyniki posegregować po najbardziej trafnych i ustawić LIMIT x,10. Na razie zrobiłem SELECT'a dla dwóch tabel (bez stronicowania i sortowania wyników):
Jakbym dodał limit na końcu to wyniki z drugiej tabeli by się wcale nie wyświetliły (nawet jakby słowo szukane było trafione w 100%) dlatego chciałbym posortować wyniki od najlepiej pasujących i wtedy dopiero ograniczyć wyświetlanie. Przeszukałem już sporo stron, i sporo się dowiedziałem ale nie mogę znaleźć rozwiązania na własnie ten problem. Z góry dzięki ! -- EDIT -- Trochę pokombinowałem i uzyskałem coś takiego:
Ale od razu można zauważyć, że score wyników jest zależny od ilości wyników z danej tabeli. Chciałbym każdą tabelę ograniczyć aby nie "przytłumiła" wyników z drugiej tabeli ("sprawiedliwość"). Już prawie jest to co chce uzyskać ale to tylko prawie... :/ Czyli jak zrobić aby waga nie była uzależniona od ilości wyników TYLKO o samej trafności słowa ? Ten post edytował Sztef89 7.11.2011, 14:30:48 |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 1 527 Pomógł: 438 Dołączył: 28.06.2011 Skąd: Warszawa Ostrzeżenie: (0%) ![]() ![]() |
Słyszałeś o czymś takim jak WIDOK w sql? jeśli nie zapoznaj się z tym i zastosuj (IMG:style_emoticons/default/wink.gif) (tyle powinno Ci wystarczyć)
Mały komentarz: Jak już poczytasz to zrób widok złączenia tych 7 - miu tabel o których była mowa. Bez żadnych sprawdzań/szukań itp... po prostu zadbaj o to by widok stał się jedną wielką tabelą połączoną z tych 7. Wtedy do takiego widoku odwołujesz się jak do tablicy (IMG:style_emoticons/default/wink.gif) Pamiętaj jednak - widok nie jest zapisywany oddzielnie jako tabela to tylko taki skrót - co oznacza, że to łączenie jest wykonywane najpierw a następnie twoje szukaniu w widoku więc postaraj się aby w widoku było jak najmniej pól - ze względów wydajności - tylko te, które potrzebujesz. |
|
|
![]() ![]() |
![]() |
Aktualny czas: 9.10.2025 - 21:35 |