Torna indietro   Hardware Upgrade Forum > Software > Programmazione

MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2009, 17:21   #1
anonimizzato
 
Messaggi: n/a
[SQL] alberatura a livelli incogniti

Ciao a tutti, cerco subito di spiegare il problema:

Ho una porzione di DB che in relazione a certi prodotti associa una categorizzazione "FINO" a 3 livelli.

Avendo come idea questo schema:

Categoria > sotto_categoria > sotto_sotto_categoria

Io posso avere un prodotto in uno qualsiasi di questi livelli quindi, a priori, non conosco il livello di "profondità" di un prodotto.

La tabella delle categorie è unica dove per tenere traccia della struttura utilizzo la classica situazione:

Codice:
categoriaID
categoria_parentID
Nell'SQL di recupero dati referenzio appunto 3 volte la stessa tabella in modo da costruire i 3 (max) livelli, ma da qui il problema.

Provate subito a guardare l'allegato per avere un'idea chiara.

Quando ho 3 livelli, gli stessi si dispongono nella SELECT nella situazione ideale, mentre se sono di meno ho valorizzati a "NULL" i campi sbagliati.

Questo molto semplicemente perchè, nel ricostruire l'alberatura, parto dall'ID della categoria associata al prodotto e RISALGO, tuttavia, non conoscendone a priori il livello di "profondità" non so come presentare nella SELECT SQL i dati nel modo corretto.

Per chiarirci, il penultimo record recuperato (vedi allegato) dovrebbe avere:

Categoria: Cucito
Categoria2: Tagliacuci
Categoria3: NULL

Invece mi ritrovo con:
Categoria: NULL
Categoria2: Cucito
Categoria3: Tagliacuci

Potete aiutarmi?

Grazie.

Ultima modifica di anonimizzato : 12-07-2009 alle 10:29.
  Rispondi citando il messaggio o parte di esso
Old 16-02-2009, 17:49   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Se il motore che usi e' Oracle, l'estensione per le query ricorsive ad albero e' gia' presente da parecchi anni.

Se non usi Oracle ma sai a priori che il numero massimo di ascendenti e' fisso, come 3, allora si puo' fare in SQL standard, non troppo elegante ma funzionale


Codice:
SELECT ID1.Nome,ID2.Nome,ID3.Nome
FROM tabella ID1
LEFT OUTER JOIN tabella ID2 ON (id1.id=id2.parentid)
LEFT OUTER JOIN tabella ID3 ON (id2.id=id3.parentid)
WHERE ID1.parentid is NULL
Forse avevi dimenticato la clausola WHERE di inizio, ovvero chi sta al primo livello avra' nessuno come parent.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2009, 18:08   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Se devi usare questa query all'interno di qualche linguaggio (mi immagino PHP), ricostruisciti l'albero tramite codice nel linguaggio che usi
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2009, 18:50   #4
CozzaAmara
Senior Member
 
L'Avatar di CozzaAmara
 
Iscritto dal: Nov 2008
Messaggi: 411
edit.
__________________
CozzaAmara è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2009, 18:53   #5
anonimizzato
 
Messaggi: n/a
Si esatto, uso PHP e avevo già pensato a questa soluzione.

Solo volevo capire se ci fosse un modo più "elegante" per farlo direttamente in SQL.
  Rispondi citando il messaggio o parte di esso
 Rispondi


MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Gwynne Shotwell (presidente di SpaceX): ...
ISRO lancerà il primo modulo della stazi...
Lo sfondo animato del tuo PC potrebbe es...
Dopo la RAM, Framework annuncia l'aument...
Google Home Speaker ufficiale: è il prim...
Spotify: i nomi utente stanno per divent...
Il limite vero dei data center AI sono g...
AMD conferma i nuovi Threadripper: Zen 6...
Stop all'ADSL per WindTre: continua la m...
HPE punta sull'IA agentica e dichiara gu...
macOS avvisa quando si incolla un comand...
Everpure ridisegna lo storage per l’IA: ...
NVIDIA RTX Remix 1.5: realizzare remaste...
Come configurare Windows 11 like a pro, ...
Windows 11 cambia finalmente la gestione...
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: 00:43.


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