• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed Kategorie w wyszukiwarce produktów

Object Storage Arubacloud
0 głosów
90 wizyt
pytanie zadane 15 września 2016 w PHP przez Mistrz0000000 Bywalec (2,780 p.)
zamknięte 15 września 2016 przez Mistrz0000000

WItam, mam taki problem z filtrowaniem produktów że normalnie działa, a kiedy próbuję wyszukiwać produkty to nie działa, akiedy z kodu wyszukiwarki usunę kategorie to działa, ale z samym sortowaniem ceny.

Mam taki kod:

function search_product()
{
    $page = $_GET['p'];
    $limit = 8;
    $page = $_GET['p'];
    if($page==0 || $page==1)
    {
        $strona= 0;
    }else{
        $strona = ($page*$limit)-$limit;
    }

    switch($_POST['category'])
    {
        case'coins':
            $_SESSION['category'] = $_POST['category'];
            break;
        case'testy':
            $_SESSION['category'] = $_POST['category'];
            break;
        case'wszystko':
            $_SESSION['category'] = null;
            break;
        default:
            break;
    }

    switch($_POST['filter'])
    {
        case'najmniejsza':
            if(isset($_SESSION['category']))
            {
                $phpro_category = filter_var($_SESSION['category'], FILTER_SANITIZE_STRING);
                $phpro_search_name = filter_var($_SESSION['product_search'], FILTER_SANITIZE_STRING);
                $stmt = getDBH()->prepare("SELECT * FROM products WHERE name LIKE :search_name AND category=:category ORDER BY price ASC LIMIT $strona,8");
                $stmt->bindValue(':search_name','%'.$phpro_search_name.'%');
                $stmt->bindParam(':category', $phpro_category, PDO::PARAM_STR);
                $stmt->execute();
            }else{
                $stmt = getDBH()->prepare("SELECT * FROM products ORDER BY price LIMIT $strona,8");
                $stmt->execute();
            }
            break;
        case'najwieksza':
            if(isset($_SESSION['category']))
            {
                $phpro_category = filter_var($_SESSION['category'], FILTER_SANITIZE_STRING);
                $phpro_search_name = filter_var($_SESSION['product_search'], FILTER_SANITIZE_STRING);
                $stmt = getDBH()->prepare("SELECT * FROM products WHERE name LIKE :search_name AND category=:category ORDER BY price DESC LIMIT $strona,8");
                $stmt->bindValue(':search_name','%'.$phpro_search_name.'%');
                $stmt->bindParam(':category', $phpro_category, PDO::PARAM_STR);
                $stmt->execute();
            }else{
                $stmt = getDBH()->prepare("SELECT * FROM products ORDER BY price DESC LIMIT $strona,8");
                $stmt->execute();
            }
            break;
        default:
            if(isset($_SESSION['category']))
            {
                $phpro_category = filter_var($_SESSION['category'], FILTER_SANITIZE_STRING);
                $phpro_search_name = filter_var($_SESSION['product_search'], FILTER_SANITIZE_STRING);
                $stmt = getDBH()->prepare("SELECT * FROM products WHERE name LIKE :search_name AND category=:category ORDER BY price ASC LIMIT $strona,8");
                $stmt->bindValue(':search_name','%'.$phpro_search_name.'%');
                $stmt->bindParam(':category', $phpro_category, PDO::PARAM_STR);
                $stmt->execute();
            }else{
                $stmt = getDBH()->prepare("SELECT * FROM products ORDER BY price LIMIT $strona,8");
                $stmt->execute();
            }
            break;

    }

    echo '<div class="text5">Wyniki wyszukiwania dla: &nbsp;'.$_SESSION['product_search'].'</div><div class="products">';
    while ($r = $stmt->fetch(PDO::FETCH_ASSOC)) {

        echo'
    	<div class="col-sm-6 col-md-4">
	<input type="hidden" name="id" value="'.$r['id'].'">
    <input type="hidden" name="price" value="'.$r['price'].'">
    <input type="hidden" name="count" value="'.$r['name'].'">
		<div class="thumbnail">
			<img src="../graph/'.$r['picture'].'" alt="" class="img-responsive">
			<div class="caption">
				<h3 class="text-left">'.$r['name'].'</h3>
				<p class="text-left">Cena: '.$r['price'].'zł</p>
				<div class="btn-toolbar text-center">
					<button type="submit" name="buy_product" class="btn btn-primary pull-right">Szczegoły</button>
				</div>
			</div>
		</div>
	</div>';
    }
    echo '</div><div style="clear: both"></div>';
}

 

komentarz zamknięcia: rozwiązane, poprostu dla else nie ustwaiłem że ma wyszukiwać w bazie danych podobne rekordy

Podobne pytania

0 głosów
1 odpowiedź 267 wizyt
pytanie zadane 5 września 2016 w PHP przez Mistrz0000000 Bywalec (2,780 p.)
+1 głos
5 odpowiedzi 226 wizyt
pytanie zadane 23 listopada 2021 w PHP przez BarSki13 Obywatel (1,250 p.)
+2 głosów
0 odpowiedzi 149 wizyt
pytanie zadane 17 października 2021 w PHP przez szpon12 Obywatel (1,220 p.)

92,551 zapytań

141,397 odpowiedzi

319,527 komentarzy

61,936 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...