Smarty Forum Index Smarty
WARNING: All discussion is moving to https://reddit.com/r/smarty, please go there! This forum will be closing soon.

Forecah, petla w petli

 
This forum is locked: you cannot post, reply to, or edit topics.   This topic is locked: you cannot edit posts or make replies.    Smarty Forum Index -> Language: Polish
View previous topic :: View next topic  
Author Message
Stef@n
Smarty n00b


Joined: 07 Jul 2008
Posts: 1

PostPosted: Mon Jul 07, 2008 9:09 am    Post subject: Forecah, petla w petli Reply with quote

Witam,
Coś mi nie wychodzi z tym Smarty Very Happy. Kolejny dzień i kolejny problem. Wyświetlam z bazy MySql tabele kategorii gdzie jedna kategoria ma kilka podkategorii. Wszystko połączone "id". Problem polega na tym że pobieram dane z tabeli Kategorie i Podkategorie. Przesyłam dane do Smarty. W smarty Tworze pętle "foreach" by wyświetlał Kategorie a w tej pętli drugą pętle "foreach" z warunkiem "if" gdzie kategorie.id_kategorii == podkategorie.id_kategorii i wszystko było by git ale druga pętla przetwarza dane tylko raz. Więc wynik prawidłowy będzie tylko do kategorii która jest pierwsza wyświetlana.

Bardzo proszę o pomoc jak rozwiązać ten problem by druga pętla ładowała za każdym razem ponownie dane z podkategorii.

Tabela MySql wygląda tak:

Code:

--
-- Struktura tabeli dla  `kategorie`
--

CREATE TABLE `kategorie` (
  `id_kategorii` int(11) NOT NULL auto_increment,
  `nazwa_kategorii` varchar(40) NOT NULL default '',
  PRIMARY KEY  (`id_kategorii`)
) TYPE=MyISAM AUTO_INCREMENT=5 ;

--
-- Zrzut danych tabeli `kategorie`
--

INSERT INTO `kategorie` VALUES (1, 'Wiadomości');
INSERT INTO `kategorie` VALUES (2, 'Rozrywka');
INSERT INTO `kategorie` VALUES (3, 'Technologia');
INSERT INTO `kategorie` VALUES (4, 'Różne');

-- --------------------------------------------------------

--
-- Struktura tabeli dla  `podkategorie`
--

CREATE TABLE `podkategorie` (
  `id_podkategorii` int(11) NOT NULL auto_increment,
  `id_kategorii` int(11) NOT NULL default '0',
  `nazwa_podkategorii` varchar(40) NOT NULL default '',
  PRIMARY KEY  (`id_podkategorii`,`id_kategorii`)
) TYPE=MyISAM AUTO_INCREMENT=13 ;

--
-- Zrzut danych tabeli `podkategorie`
--

INSERT INTO `podkategorie` VALUES (1, 1, 'Polityk');
INSERT INTO `podkategorie` VALUES (2, 1, 'Sport');
INSERT INTO `podkategorie` VALUES (3, 1, 'Pogoda');
INSERT INTO `podkategorie` VALUES (4, 1, 'Kultura');
INSERT INTO `podkategorie` VALUES (5, 2, 'Muzyka');
INSERT INTO `podkategorie` VALUES (6, 2, 'Filmy');
INSERT INTO `podkategorie` VALUES (7, 2, 'Książki');
INSERT INTO `podkategorie` VALUES (8, 2, 'Imprezy');
INSERT INTO `podkategorie` VALUES (9, 2, 'Motoryzacja');
INSERT INTO `podkategorie` VALUES (10, 3, 'PC');
INSERT INTO `podkategorie` VALUES (11, 3, 'GSM');
INSERT INTO `podkategorie` VALUES (12, 4, 'Ciekawostki');


kod PHP
Code:

<?php
   //Łaczy z baza
   $wyniki_k = mysql_query ("SELECT * FROM kategorie");
      
      //Pobieranie danych
      while ($rekord_k = mysql_fetch_array ($wyniki_k)) {
         $dane_k['id_kategorii'] = $rekord_k['id_kategorii']; // id kategorii
         $dane_k['nazwa_kategorii'] = $rekord_k['nazwa_kategorii']; //Nazwa Kategorii
            $dane_tablica_k[] = $dane_k;      
      }
   
   //Łaczenie z baza
   $wyniki_pk = mysql_query ("SELECT * FROM podkategorie");   
               
         //Pobieranie danych z bazy
         while ($rekord_pk = mysql_fetch_array ($wyniki_pk)) {
            $dane_pk['id_podkategorii'] = $rekord_pk['id_podkategorii']; // id podkategorii
            $dane_pk['id_kategorii'] = $rekord_pk['id_kategorii']; // id kategorii
            $dane_pk['nazwa_podkategorii'] = $rekord_pk['nazwa_podkategorii']; //Nazwa podategorii
               $dane_tablica_pk[] = $dane_pk;
         }
      
   //Przekazywanie zmiennych do Smarty
   $smarty -> assign('dane_k', $dane_tablica_k); //Dane Kategorie
   $smarty -> assign('dane_pk', $dane_tablica_pk); //Dane Podkategorie
?>


kod TPL
Code:

      {foreach item=dane_k from=$dane_k}
         <div><b>{$dane_k.nazwa_kategorii}</b>:</div>
            {foreach item=dane_pk from=$dane_pk}
            {if $dane_pk.id_kategorii == $dane_k.id_kategorii}
               <div> - {$dane_pk.nazwa_podkategorii}</div>
            {/if}
            {/foreach}
      {/foreach}


Dziękuje z góy za każdą pomoc.
Back to top
View user's profile Send private message
fornve
Smarty Rookie


Joined: 25 Apr 2008
Posts: 29
Location: Sheffield, UK

PostPosted: Wed Jul 16, 2008 11:15 pm    Post subject: Reply with quote

a co pokazuje var_dump( $dane_tablica_pk ) na koncu kodu php?

probowales zmienic kod tpl w petlach foreach zamiast:

{foreach item=dane_k from=$dane_k}

wstawic:

{foreach item=dana_k from=$dane_k}

ewentualnie dodac:

{foreach item=dana_k from=$dane_k name=mainloop}
Back to top
View user's profile Send private message Visit poster's website
Display posts from previous:   
This forum is locked: you cannot post, reply to, or edit topics.   This topic is locked: you cannot edit posts or make replies.    Smarty Forum Index -> Language: Polish All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group
Protected by Anti-Spam ACP