![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 9 Pomógł: 0 Dołączył: 23.04.2014 Ostrzeżenie: (0%) ![]() ![]() |
Witam
Chciałbym uzyskać taki efekt możliwie najprostszym sposobem: ../category/subcategory/id ze wszystkimi możliwymi kombinacjami np: .../id, ../subcategory, ../subcategory/id Otóż w zasadzie napisałem kod, który działa. Trzy niewiadome były jeszcze znośne, ale potrzebuje jeszcze utworzyć podobny na ok. 5 niewiadomych (już sama myśl mnie przeraża), dlatego chciałem się spytać czy nie ma czasem jakiegoś prostszego sposobu? Mam przeczucie, że jednak nie do końca wykorzystuje możliwości frameworka (mój pierwszy projekt). A jeśli chodzi o wady poniższego kodu to: -każdorazowo muszę sprawdzać 'category_name', czyli po prostu warianty kategorii. Jest ich ok.7, więc jest jeszcze ok. -sam kod to potworek (wkleiłem tylko pierwszy szkielet). W rzeczywistości w każdym if-ie rozważanych jest jeszcze kilka możliwości z każdorazowym połączeniem z bazą danych. routes.php HomeController
Do tego wszystkiego dochodzi parę drobnych filtracji przesyłanych za pomocą sesji, w zależności od tego co wybierze użytkownik w checkbox-ie. Ten post edytował damian1 8.09.2014, 17:50:53 |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 9 Pomógł: 0 Dołączył: 23.04.2014 Ostrzeżenie: (0%) ![]() ![]() |
Dziękuję za podpowiedzi, z pewnością niektóre wykorzystam, aczkolwiek nie rozwiązują do końca moich problemow.
A w zasadzie 1 problemu: jak szybko rozpoznać, że {category}, nie jest {subcategory} i podam przykład: www.adres-strony.pl/krajobraz/góry/skały/ I jeśli użyłbym $request = Request::segment(2) pobrałoby góry, a jeśli adres wyglądałby inaczej: www.adres-strony.pl/krajobraz/skały/ pobrałoby skały i powstałby mały konflikt w bazie danych: 1)$photos = Photo::where('kryterium_ksztalt_terenu', '=', $request)->get(); 2)$photos = Photo::where('kryterium_przedmiot', '=', $request)->get(); a nie mógłbym na stałe użyć pierwszego adresu, bo skały są nie tylko w górach, ale też na nizinach, nad morzem... Poprzez sesje filtruje dodatkowo (w razie potrzeby) kolor, rozmiar, kształt... W moim pierwszym kodzie miałem 3 "niewiadme". Wersja z 2 możliwościami (Request::segment(1), Request::segment(2)) // www.adres-strony.pl/kategoria/7 Id potraktowana jako liczba
Na wyjściu otrzymuje $category=kategoria, $galeria=null, $id=7 i teraz mogę wygodnie przeszukiwać bazę danych. Problem polega na tym, że muszę jeszcze rozważyć kategoria/galeria ; galeria/5, czyli rozróżnić kategorie i galerię. W związku z tym przeszukuje z góry ustalone możliwości kategorii i jeśli ich nie znajduję ustawiam $kategoria=null, $galeria= to co wpisane; I teraz podobny problem muszę rozważyć na pięciu niewiadomych. Myślałem, że jest jakiś prostszy sposób, ale bez własnej funkcji chyba się jednak nie obejdzie. I teraz pytanie jak zrobić to najbardziej optymalnie? Na razie najlepszy pomysł jaki mi przychodzi do głowy to przedrostki: kat-kategoria,sub-subcategoria... tylko nie w Route, bo by nie działało, tylko po prostu jako nazwy i odpowiednio je później wykryć. Nie mniej tego wolałbym uniknąć. Dziękuje za dotychczasowa pomoc. <!-- EDIT --> Ok, albo w sumie zrobię jak mówicie, a skałę potraktuje jako wyjątek i będzie ewentualnie dosyłana w sesji. Mam jeszcze tylko kilka pytań optymalizacyjnych (w sumie może głupie, ale tylko domyślam się niektórych odpowiedzi). Ktoś ma doświadczenie co może być szybsze? 1) Zapisanie kategorii, subkategorii w bazie danych jako 1,2,3..... i filtrowanie w PHP if($category == 'gory'){$category =1;} i wyszukanie: ...where('category', '=', $category)..., czy od razu zapisanie w bazie danych "stringów"? 2)Powinienem stworzyć relacyjną bazę danych np: category, subcategory, subcategory2 - 1 tabelka, tile, lokazlizacja, opis, widoczność - 2 tabelka? Czy nie będzie przeszkadzało jak bede miał wszystko w 1 tabelce z indeksowaniem, niektórych kolumn? albo jakaś dobra strona, gdzie mógłbym o tym doczytać... Ten post edytował damian1 9.09.2014, 10:54:23 |
|
|
![]() ![]() |
![]() |
Aktualny czas: 4.10.2025 - 21:27 |