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

Wyświetlanie tylko jednego echa w pętli

VPS Starter Arubacloud
0 głosów
189 wizyt
pytanie zadane 31 sierpnia 2017 w PHP przez sc4rface Dyskutant (7,710 p.)

Cześć, zamieszczam swój fragment kodu, z którym mam mały problem. 

$result = array();

            foreach ($products as $detail) {
                
                $cid = $detail['category_id'];
                $pid = $detail['product_id'];
                $status = $detail['active'];
                $result[$cid][$pid] = $status;

            }
            
            $multiplier = $result[$cid][$pid];
            $counter = count($result[$cid]);
            $multiplier2 = 1;
            
            for ($id = 0; $id < $counter; $id++) {
                $multiplier = $multiplier * $multiplier2;
            }
                                     
            if ($multiplier == 0) {
                echo 'Kategoria ID '.$cid.' pusta';
            } else {
                echo 'Kategoria ID '.$cid.' zawiera produkty';
            }

Generuje on następującą tablice:

Array
(
    [221] => Array
        (
            [1] => 0
            [2] => 0
        )

    [1437] => Array
        (
            [3] => 0
        )

)

Wszystko byłoby spoko, gdyby nie fakt - że wyświetla tylko jedno echo - mianowicie ostatni rekord tablicy. Działa to na tej zasadzie, że skrypt pobiera wartości [1][2][3] i tak dalej (nie sa one po kolei, tutaj tak się złożyło) i mnoży je przez siebie w odpowiednim ID nadrzędnym. Jeśli wynik mnożenia jest > 0 wyświetla "kategoria zawiera produkty" jeżeli nie, pusta. Problem w tym, że wyświetla tylko jedno echo - a na przykładzie tej tablicy, powinien wyświetlić ich dwa - mianowicie 2x "kategoria jest pusta". Jak mogę to naprawić?

1 odpowiedź

+2 głosów
odpowiedź 31 sierpnia 2017 przez Ehlert Ekspert (212,630 p.)
Kod jest strasznie nieczytelny. Jest to fragment kodu, więc nie wiem jakie dane przetwarzasz i po co robisz to w taki sposób. Proponuję dołączenie reszty, lub skorzystanie z IDE + Xdebuga. Na ten moment nawet, gdybym chciał Ci pomóc jestem wybity z kontekstu.
komentarz 31 sierpnia 2017 przez sc4rface Dyskutant (7,710 p.)
Drugi raz łapię się na tym, że komplikuję sobie życie. Ostatnio również pytałem o rozwiązanie łączenia trzech tablic w jedną i jej sformatowanie, a okazało się, że spokojnie mogłem wykonać wszystko jednym zapytaniem do bazy...
2
komentarz 31 sierpnia 2017 przez Boshi VIP (100,240 p.)
Z zasady baza powinna być tak zaprojektowana abyś nie musiał w phpie bawić się w operacje logiczne na tablicach. Wyciągasz z bazy to co potrzebujesz, wstawiasz ewentualnie jakiś warunek na podstawie tychże danych i wtedy masz jasność :)
komentarz 31 sierpnia 2017 przez sc4rface Dyskutant (7,710 p.)
edycja 31 sierpnia 2017 przez sc4rface

No dobra, teraz mój kod drastycznie się zmienił :D Zawiera 3 linijki? Tak czy inaczej dalej coś nie gra, bowiem dalej te kategorie się dublują. 

foreach ($products as $detail) {

echo 'Pusta kategoria: ' .$detail['category_id']. '<br />'; 
                
}

Totalnie nie wiem co jest tutaj powodem, tablica $products wygląda w ten sposób:

Array
(
    [0] => Array
        (
            [product_id] => 1
            [0] => 1
            [category_id] => 221
            [1] => 221
            [active] => 0
            [2] => 0
        )

    [1] => Array
        (
            [product_id] => 2
            [0] => 2
            [category_id] => 221
            [1] => 221
            [active] => 0
            [2] => 0
        )

    [2] => Array
        (
            [product_id] => 3
            [0] => 3
            [category_id] => 1437
            [1] => 1437
            [active] => 0
            [2] => 0
        )

    [3] => Array
        (
            [product_id] => 4
            [0] => 4
            [category_id] => 1437
            [1] => 1437
            [active] => 0
            [2] => 0
        )

    [4] => Array
        (
            [product_id] => 5
            [0] => 5
            [category_id] => 216
            [1] => 216
            [active] => 0
            [2] => 0
        )

)

 

@EDIT

Tak sobie to przemyślałem i w jaki sposób miałoby to działać, active nie jest znacznikiem kategorii, a produktu. Działa to w ten sposób, że jeśli żadne produkty w kategorii nie są aktywne - wtedy kategoria nie jest aktywna. Jeśli choć jeden jest aktywny, jest aktywna. Istnieje możliwość zapisania tego w czystym SQL'u, nie wydaje mi się.

komentarz 31 sierpnia 2017 przez Ehlert Ekspert (212,630 p.)
Istnieje. Ale masz źle zaprojektowaną bazę danych.
komentarz 31 sierpnia 2017 przez sc4rface Dyskutant (7,710 p.)
Da radę to jakoś obejść? Przeprojektowanie bazy odpada - nie ja ją tworzyłem, tym bardziej jest na to zbyt obszerna.

Podobne pytania

+1 głos
1 odpowiedź 192 wizyt
0 głosów
2 odpowiedzi 942 wizyt
0 głosów
1 odpowiedź 537 wizyt
pytanie zadane 12 września 2017 w JavaScript przez kevin Mądrala (5,010 p.)

92,453 zapytań

141,262 odpowiedzi

319,086 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...