![]() |
![]() ![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 155 Pomógł: 0 Dołączył: 22.06.2010 Ostrzeżenie: (0%) ![]() ![]() |
Witam mam takie proste zapytanie:
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 ![]() |
|
|
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 76 Pomógł: 19 Dołączył: 19.01.2010 Ostrzeżenie: (0%) ![]() ![]() |
Cytat AND cp.`id_product_attribute` = pa.`id_product_attribute` użyj join zamiast where |
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 155 Pomógł: 0 Dołączył: 22.06.2010 Ostrzeżenie: (0%) ![]() ![]() |
Zaraz będę testował. Mam jeszcze jedno pytanie odnośnie koszyka. Klient może mieć wiele koszyków, w tabeli jest id koszyka, id klienta i data dodania przedmiotu. Kiedy klient ma 2 koszyki i w każdym po 2 przedmioty sumuje mi ich wartość a chcę brać tylko z aktywnego czyli tego w którym data dodania przedmiotu jest najwyższa lub id koszyka jest najwyższe. Jak to zapisać i czy da si takie zapytanie mysql zrobić żeby pobierało ale nie ze wszystkich tylko tego gdzie id koszyka jest najwyższe.
|
|
|
![]()
Post
#4
|
|
Grupa: Zarejestrowani Postów: 76 Pomógł: 19 Dołączył: 19.01.2010 Ostrzeżenie: (0%) ![]() ![]() |
|
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 155 Pomógł: 0 Dołączył: 22.06.2010 Ostrzeżenie: (0%) ![]() ![]() |
Jest to jakieś rozwiązanie, ale lepiej chyba pobiorę najpierw tą tabelę wyciągnę id koszyka i zmienną podstawie do zapytania mysql.
|
|
|
![]()
Post
#6
|
|
Grupa: Zarejestrowani Postów: 78 Pomógł: 4 Dołączył: 21.03.2005 Ostrzeżenie: (0%) ![]() ![]() |
Dużo nie musisz zmieniać, bo to nie problem joina, ani innych gramlinów.
Jeżeli nie ma atrybutu to pole pa.`price` przyjmuje wartość NULL.
daje 0
daje 10 musisz jedynie zrobić transformacje null na ZERO - ifem, czy jakąś funkcją. -------------------- ==============================================
Bo ja jestem Wróbelek Htmlek ============================================== |
|
|
![]() ![]() |
![]() |
Aktualny czas: 21.08.2025 - 04:00 |