Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Peugeot Polygon Concept: ecco il futuro delle utilitarie
Peugeot Polygon Concept: ecco il futuro delle utilitarie
Polygon è la concept car di Peugeot che mostra il futuro delle soluzioni del segmento B: tra design compatti e innovativi affiancati da dimensioni compatte uno scherzo dalla manovrabilità incredibile per le manovre a bassa velocità
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
OPPO ha portato in Italia, dal 1° luglio 2026, Reno16 Pro: display AMOLED da 6,32 pollici a 144Hz, tripla fotocamera con sensore principale da 200 megapixel, chip Dimensity 8550 Super e batteria da 6000mAh, al prezzo di lancio di 899 euro. Lo abbiamo provato per due settimane insieme al nuovo accessorio Bubble, per capire se la formula compatta della serie regge ancora di fronte a un listino da 1099 euro
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-12-2013, 19:04   #1
isee
Senior Member
 
Iscritto dal: Sep 2010
Messaggi: 718
[SQL/PHP] - Colonne dinamiche

Salve gente,

ho un problema con la gestione di una base di dati e relativa web app in PHP. Vi faccio il punto della situazione! Ho da gestire dei prodotti, questi prodotti hanno dei campi obbligatori, altri (opzionali) cambiano in base alla tipologia di prodotto. Le tipologie quindi, sono una collezione di questi campi opzionali, a loro volta possono essere modificati/rimossi da un addetto ai lavori.

Esempio pratico:
-ProdottoA
-nome: XX
-peso: YY
-tipologia: ferro
-peso specifico (opzionale): XYW
-lucententezza (opzionale): WYXX

-ProdottoB
-nome: HJPA
-peso: GHH
-tipologia: carbone
-derivazione (opzionale): BLABLA
-data acquisto (opzionale): GG/MM/AAAA

Quindi, le tipologie "ferro" e "carbone" hanno campi diversi opzionali. Un admin può decidere di aggiungere o rimuovere o cambiare uno di questi campi, in base alle esigenze, e può anche inserire nuove tipologie. Detto ciò, un "operaio" che deve inserire un prodotto immette i campi obbligatori (nome, peso), seleziona la tipologia ed escono fuori i campi che dipendono dalla tipologia (opzionali, cioè può anche non inserirli).

Partiamo dal fatto che, con le conoscenze derivate dalle lezioni universitarie, questo problema non sono in grado di risolverlo a dovere da solo (nemmeno i colleghi). Non so proprio come impostare la base di dati e come generare colonne dinamiche per l'eventuale modifica dei campi opzionali.
Ok, in realtà l'idea c'è ma è così:

- table tipologie (id, nometip)
- table campi (id, idtipologia, nome_campo)
- table relazione_tipologie_campi (id, idtipologia, idcampo, idprodotto, valore)
- table prodotti (id, nome, peso, tipologia)


A me sembra proprio brutta come cosa e nemmeno tanto buona, ma al momento non sono in grado di trovare una soluzione migliore. Avete suggerimenti?
__________________
Ho venduto a: micanto1(muletto)-franzgranata(Alimentatore)-piff84(Desktop)-s3n3ca(netbook)-
helmen84(Nexus 5)

Ultima modifica di isee : 29-12-2013 alle 14:20.
isee è offline   Rispondi citando il messaggio o parte di esso
Old 31-12-2013, 13:49   #2
isee
Senior Member
 
Iscritto dal: Sep 2010
Messaggi: 718
up
__________________
Ho venduto a: micanto1(muletto)-franzgranata(Alimentatore)-piff84(Desktop)-s3n3ca(netbook)-
helmen84(Nexus 5)
isee è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2014, 14:14   #3
tigroneveloce
Member
 
Iscritto dal: Apr 2008
Messaggi: 125
Così, a prima vista, io farei così...
Ogni tipologia con la sua tabella dedicata nella quale ogni record rappresenta un campo.
Poi, un'unica tabella prodotti la quale contiene tutte le colonne di tutte le tabelle tipologie...

In pratica:

table ferro
id1 - nome
id2 - peso
id3 - peso specifico
id4 - lucentezza

table carbone
id1 - nome
id2 - peso
id3 - derivazione
id4 - data acquisto

table prodotti (con tutti i campi delle tipologie)
tipologia - nome - peso - peso specifico - lucentezza - derivazione - data acquisto

In questo modo non dovrebbero esserci grossi problemi nel caso di aggiornamenti da parte dell'admin...
Nel caso di una nuova tipologia si creerebbe una nuova tabella dedicata; nel caso di un nuovo campo, una semplice insert nella table tipologia interessata e un'aggiunta di colonna alla table prodotti (se non è già presente un campo comune...).

Poi, con javascript, php e i form html puoi gestire tutto il resto...

Ciao e buon anno.

Ultima modifica di tigroneveloce : 01-01-2014 alle 14:18.
tigroneveloce è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2014, 14:49   #4
isee
Senior Member
 
Iscritto dal: Sep 2010
Messaggi: 718
Quote:
Originariamente inviato da tigroneveloce Guarda i messaggi

table prodotti (con tutti i campi delle tipologie)
tipologia - nome - peso - peso specifico - lucentezza - derivazione - data acquisto
Ciao e buon anno. In questo modo, io creo una tabella prodotti con colonne fissate anche per i campi della tipologia, ma questi possono aumentare o diminuire. Avevo pensato anche io a questa soluzione, però non funziona perché se ho una tipologia con 20 campi ed una con 200 campi (tutti diversi), che succede poi alla tabella prodotti?
__________________
Ho venduto a: micanto1(muletto)-franzgranata(Alimentatore)-piff84(Desktop)-s3n3ca(netbook)-
helmen84(Nexus 5)

Ultima modifica di isee : 01-01-2014 alle 14:54.
isee è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2014, 15:05   #5
tigroneveloce
Member
 
Iscritto dal: Apr 2008
Messaggi: 125
Quote:
Originariamente inviato da isee Guarda i messaggi
...ma questi possono aumentare o diminuire.
Non succederebbe niente alla tabella prodotti; al limite ci si troverebbe con un numero di campi inutilizzati...

Piuttosto, è quel "diminuire" che non mi convince...
Che cosa intendi, perdere i dati?
Perché se, per esempio, il campo "derivazione" della tipologia "carbone", viene eliminato dall'admin, allora non recuperi più il valore contenuto (BLABLA).
tigroneveloce è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2014, 16:39   #6
isee
Senior Member
 
Iscritto dal: Sep 2010
Messaggi: 718
Ma sarebbe una cosa davvero poco elegante, una soluzione bruta e probabilmente evitabile. Personalmente, non prendo proprio più in considerazione una simile alternativa.
Rimango in attesa di altri aiuti comunque
__________________
Ho venduto a: micanto1(muletto)-franzgranata(Alimentatore)-piff84(Desktop)-s3n3ca(netbook)-
helmen84(Nexus 5)
isee è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2014, 17:31   #7
airon
Senior Member
 
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
A mio avviso ciò che hai pensato è proprio la soluzione più corretta. Non mi viene in mente altro di buono ed è ciò che farei pure io.

Cosa non ti convince?
airon è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2014, 17:41   #8
isee
Senior Member
 
Iscritto dal: Sep 2010
Messaggi: 718
Leggevo qualche tempo fa del fatto che è possibile creare colonne virtuali dinamicamente, però era qualcosa che attualmente va oltre le mie possibilità di studio. Magari poteva esistere qualcosa di simile, fattibile in sql e che io non ero a conoscenza, oppure un'alternativa migliore rispetto a quella che ho trovato io. Nel senso, una volta creata la tabella dei campi delle tipologie con i rispettivi valori inseriti per ogni prodotto, mi sorge il dubbio che effettivamente sia essa stessa una soluzione poco elegante.
__________________
Ho venduto a: micanto1(muletto)-franzgranata(Alimentatore)-piff84(Desktop)-s3n3ca(netbook)-
helmen84(Nexus 5)
isee è offline   Rispondi citando il messaggio o parte di esso
Old 05-01-2014, 11:58   #9
]Rik`[
Senior Member
 
L'Avatar di ]Rik`[
 
Iscritto dal: Mar 2003
Città: Perugia
Messaggi: 16302
a me la tua soluzione sembra la migliore..
]Rik`[ è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Peugeot Polygon Concept: ecco il futuro delle utilitarie Peugeot Polygon Concept: ecco il futuro delle ut...
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione Reno16 Pro: il compatto di OPPO punta su fotocam...
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
Edge AI: NVIDIA Jetson raggiungerà...
La missione robotica LINK per salvare il...
Potrebbe essere stato lanciato l'ultimo ...
PamStealer, il malware per Mac che prima...
NAVEE EXO S Pro, il robot esoscheletro p...
Samsung Galaxy A57 5G a 399€ con 256 GB:...
Volevano collegare delle aragoste vive a...
La crisi dei PC è peggiore del pr...
Alibaba pronta a vietare Claude Code ai ...
Sovranità sui dati: Cloud Firewal...
FiberCop porterà la fibra Gigabit...
Data center in Lombardia: 20 progetti sc...
Tutti i modi in cui la scommessa di Orac...
Kioxia e SanDisk sbandierano i numeri de...
iPhone 18 Pro potrebbe usare modem Qualc...
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: 05:28.


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