Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-10-2008, 11:30   #1
frizzo28
Senior Member
 
Iscritto dal: Aug 2005
Città: Roma sud
Messaggi: 590
[php/mysql] Organizzare categorie e sottocategorie

Visto che un'esempio vale piu' di mille parole vi posto subito un immaggine:

Sulla destra vedete la tabella SQL sulla sinistra il risultato che vorrei ottenere tramite il PHP. Praticamente stampare a video quella tabella come una serie di liste nidificate( UL,LI ).
Il mio problema e' proprio a livello di algoritmo non riesco a trovare un modo per gestire correttamente categorie e sottocategorie...
Avete qualche idea?

p.s La tabella che vedete nell'immaggine e' cosi' organizzata
id_cat=Id della categoria univoco
nome=Il nome della categoria/sottogategoria
id_principale=Settato a 0 se e' un categoria principale altrimenti settato al valore dalla categoria "padre"...
grazie
ciao
__________________
-Mac Book intel core duo 1,83GHz, 1,25 Gb RAM
-Amd athlon 64 dual core 4400+, 2 GB RAM, Asus a8n-sli Deluxe, totale 500 GB di HARD DISK(4 hdd)

Ultima modifica di frizzo28 : 28-10-2008 alle 11:33.
frizzo28 è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2008, 12:26   #2
vizzz
Senior Member
 
L'Avatar di vizzz
 
Iscritto dal: Mar 2006
Città: Bergamo
Messaggi: 2499
mi sono imbattuto in una situazione simile alla tua, se non identica e ho risolto creando prima un array contenente tutti i dati:

Codice:
while ($row = $stmt->fetch())
                {
                    if ($row['id_principale'] == 0)
                    {
                        $db_data[$row['nome']] = array();

                        $db_data[$row['nome']]['desc'] = $row['desc'];
                        $db_data[$row['nome']]['link'] = $row['link'];
                        $db_data[$row['nome']]['selected'] = ($item == $row['nome']) ? 1 : 0;
                        $db_data[$row['nome']]['subs'] = array();
                    }
                    else
                    {
                        if (array_key_exists($row['id_principale'], $db_data))
                        {
                            $db_data[$row['id_principale']]['subs'][$row['nome']] = array();
                            $db_data[$row['id_principale']]['subs'][$row['nome']]['desc'] = $row['desc'];
                            $db_data[$row['id_principale']]['subs'][$row['nome']]['link'] = $row['link'];
                            $db_data[$row['id_principale']]['subs'][$row['nome']]['selected'] = ($item == $row['nome']) ? 1 : 0;
                        }
                    }
                }
a questo punto ti è più comodo, visto che se un padre ha dei figli te li ritrovi nell'array subs.
se hai domande chiedi pure.

edit: però ho visto solo ora che tu hai più livelli, io ne avevo solo due...vedi se riesci a riadattare il codice =)
__________________
ho concluso con: kvegeta, doctordb, Leland Gaunt.

Ultima modifica di vizzz : 28-10-2008 alle 12:28.
vizzz è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2008, 13:14   #3
frizzo28
Senior Member
 
Iscritto dal: Aug 2005
Città: Roma sud
Messaggi: 590
@vizz ti ringrazio ma in effetti il codice che hai postato e' per solo 2 livelli invecie io dovrei gestirne N di livelli...
__________________
-Mac Book intel core duo 1,83GHz, 1,25 Gb RAM
-Amd athlon 64 dual core 4400+, 2 GB RAM, Asus a8n-sli Deluxe, totale 500 GB di HARD DISK(4 hdd)
frizzo28 è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2008, 16:05   #4
kk3z
Senior Member
 
L'Avatar di kk3z
 
Iscritto dal: Nov 2003
Messaggi: 980
Scritto adesso:
Codice PHP:
<?
    
function output_categorie($id_principale)
    {
        
$sql "SELECT * FROM categorie WHERE id_principale = '$id_principale'";
        
$res mysql_query($sql);
        
        echo 
"<ul>";
        while (
$row mysql_fetch_assoc($res))
        {
            echo 
"<li>";
            echo 
$row['nome'];
            
            
//Stampa sottocategorie
            
output_categorie($row['id_cat']);
            
            echo 
"</li>";
        }
        echo 
"</ul>";
    }
    
    
output_categorie(0);
?>
Se vuoi fare in modo che si espandano (cioè siano visibili le sottocategorie) solo quando sono selezionate, beh, è un po' più complicato.
kk3z è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2008, 17:44   #5
frizzo28
Senior Member
 
Iscritto dal: Aug 2005
Città: Roma sud
Messaggi: 590
La tua soluzione funzione alla grande ecco come l'ho modificata per visualizzare solo una categoria e/o sottocategoria e tutte le sue sottocategorie quando ci si clicca...
principale.php
Codice PHP:
<?

require "connect.php";

    function 
output_categorie($id_principale)
    {
        
$sql "SELECT * FROM downcat WHERE id_principale = \"$id_principale\"";
        
$res mysql_query($sql);
        
        echo 
"<ul>";
        while (
$row mysql_fetch_assoc($res))
        {
            echo 
"<li>";
            echo 
"<a href=apricat.php?id=".$row['id_cat'].">".$row['nome']."</a>";
            
            
//Stampa sottocategorie
            
output_categorie($row['id_cat']);
            
            echo 
"</li>";
        }
        echo 
"</ul>";
    }
    
    
output_categorie(0);
?>
e poi apricat.php
Codice PHP:
<?

require "connect.php";

    function 
output_categorie($id_principale)
    {
        
$sql "SELECT * FROM downcat WHERE id_principale = \"$id_principale\"";
        
$res mysql_query($sql);
        
        echo 
"<ul>";
        while (
$row mysql_fetch_assoc($res))
        {
            echo 
"<li>";
            echo 
"<a href=apricat.php?".$row['id_cat'].">".$row['nome']."</a>";
            
            
//Stampa sottocategorie
            
output_categorie($row['id_cat']);
            
            echo 
"</li>";
        }
        echo 
"</ul>";
    }

if(isset(
$_GET['id'])){
$id=$_GET['id'];
 
$sql "SELECT * FROM downcat WHERE id_cat = \"$id\"";
        
$res mysql_query($sql);
        
        echo 
"<ul>";
        while (
$row mysql_fetch_assoc($res))
        {
            echo 
"<li>";
            echo 
"<a href=apricat.php?".$row['id_cat'].">".$row['nome']."</a>";
            echo 
"</li>";}
    
output_categorie($id);
echo 
"</ul>";
}
else 
output_categorie(0);
?>
grazie
ciao
__________________
-Mac Book intel core duo 1,83GHz, 1,25 Gb RAM
-Amd athlon 64 dual core 4400+, 2 GB RAM, Asus a8n-sli Deluxe, totale 500 GB di HARD DISK(4 hdd)

Ultima modifica di frizzo28 : 28-10-2008 alle 18:30.
frizzo28 è offline   Rispondi citando il messaggio o parte di esso
Old 28-01-2009, 19:16   #6
amadeusorrento
Junior Member
 
Iscritto dal: Jul 2008
Messaggi: 1
Quote:
Originariamente inviato da kk3z Guarda i messaggi
Scritto adesso:
Codice PHP:
<?
    
function output_categorie($id_principale)
    {
        
$sql "SELECT * FROM categorie WHERE id_principale = '$id_principale'";
        
$res mysql_query($sql);
        
        echo 
"<ul>";
        while (
$row mysql_fetch_assoc($res))
        {
            echo 
"<li>";
            echo 
$row['nome'];
            
            
//Stampa sottocategorie
            
output_categorie($row['id_cat']);
            
            echo 
"</li>";
        }
        echo 
"</ul>";
    }
    
    
output_categorie(0);
?>
Se vuoi fare in modo che si espandano (cioè siano visibili le sottocategorie) solo quando sono selezionate, beh, è un po' più complicato.

Ciao..sto leggendo questo post...e quello che devo fare è proprio questo...fare in modo che le categorie si espandono solo se cliccate...qualcuno mi sa aiutare??
amadeusorrento è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Il CEO di Epic Games Tim Sweeney ha comp...
PSSR aggiornato su PS5 Pro: Sony svela i...
Scope elettriche low cost a prezzo strac...
G-ASD di Geely, primo ADAS cinese certif...
La serie TV di Assassin's Creed su Netfl...
Nothing Phone (4a) disponibile su Amazon...
NemoClaw è la soluzione di NVIDIA...
Abarth Grande Panda ibrida: lo Scorpione...
European Hardware Awards 2026: la data &...
NVIDIA, nel futuro c'è la GPU Fey...
Doom: The Dark Ages è il primo gr...
Robot aspirapolvere ECOVACS in offerta: ...
22.000Pa e si pulisce da solo per 75 gio...
Samsung prepara i nuovi Galaxy Tab S12: ...
Virtual C-Suite: gli agenti IA di Master...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 13:48.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v