Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Dal palco di Proofpoint Protect 2025 emerge la strategia per estendere la protezione dagli utenti agli agenti IA con il lancio di Satori Agents, nuove soluzioni di governance dei dati e partnership rafforzate che ridisegnano il panorama della cybersecurity
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-10-2008, 10: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 10:33.
frizzo28 è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2008, 11: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 11:28.
vizzz è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2008, 12: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, 15: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, 16: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 17:30.
frizzo28 è offline   Rispondi citando il messaggio o parte di esso
Old 28-01-2009, 18: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


Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Trasferire una eSIM TIM sul nuovo iPhone...
Torna il super notebook Lenovo con Core ...
MacBook Pro: prima un refresh e poi il s...
Mondaic, il software nato per Marte che ...
SpaceX annuncia l'undicesimo volo del ra...
CMF lancia le sue prime cuffie over-ear:...
Condannata a Londra la protagonista dell...
Addio Amazon? ChatGPT ora ti fa comprare...
YouTube chiude la causa con Trump: accor...
Avio: contratto da 40 milioni di € da ES...
Claude Sonnet 4.5, il nuovo modello di A...
Silent Hill f è un successo: gi&a...
Nuova Jeep Compass: aperti i preordini p...
La PS5 Slim con SSD più piccolo s...
Zero combustibili fossili e controllo qu...
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: 07:53.


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