//zwraca wartosc brutto wszytkich przedm. w koszyku (bez promocji i rabatow) $suma_w_koszyku = intval(Db::getInstance()->getValue(' SELECT SUM(cp.`quantity` * p.`price` + pa.`price`) * (t.`rate` / 100 + 1) FROM `'._DB_PREFIX_.'cart` c, `'._DB_PREFIX_.'cart_product` cp, `'._DB_PREFIX_.'product` p, `'._DB_PREFIX_.'tax` t, `'._DB_PREFIX_.'product_attribute` pa WHERE cp.`id_product` = p.`id_product` AND cp.`id_cart` = c.`id_cart` AND t.`id_tax` = p.`id_tax` AND cp.`id_product_attribute` = pa.`id_product_attribute` AND c.`id_cart` = '.intval($cookie->id_cart)) );
Ma ono w sklepie pobrać sumę wartości przedmiotów w koszyku klienta. Wszystko dobrze zliczało ale niektóre przedmioty miały atrybuty które zwiększały cenę o daną kwotę.
Więc dodałem sobie + pa.`price` i dodatkową tabele z której bierze dane `'._DB_PREFIX_.'product_attribute` pa. Jest ok zlicza jak trzeba dodaje tą kwote jeśli przedmiot ma atrybut ale nie sumuje wartości przedmiotów które nie mają dodanych żadnych atrybutów. Czyli jeśli dodam do koszyka przedmiot bez atrybutu czyli w tabeli product_attribute nie ma wiersza z id przedmiotu który się doda zwraca 0. Myślałem że jeśli nie znajdzie wiersza doda 0 i wyświetli normalną ceną a tu zonk
