Torna indietro   Hardware Upgrade Forum > Software > Programmazione

AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-12-2013, 20: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 15:20.
isee è offline   Rispondi citando il messaggio o parte di esso
Old 31-12-2013, 14: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, 15: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 15:18.
tigroneveloce è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2014, 15: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 15:54.
isee è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2014, 16: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, 17: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, 18: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, 18: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, 12: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


AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
KIOXIA: 'il tempo degli SSD a basso cost...
Apple perde la sua posizione privilegiat...
CovertLabs lancia l'allarme: 198 app AI ...
Smart TV QLED da 75 pollici a 559€ su Am...
Nello Spazio l'evoluzione cambia rotta: ...
Il fondatore di Waymo critica l'FSD di T...
Rincari GPU: NVIDIA alza il costo della ...
Robot tagliaerba a 699€ su Amazon: un Se...
Nova Launcher cambia proprietà: perché t...
Stop a TikTok e Instagram dopo le 21: pa...
A Seul in arrivo nuovi incentivi per aut...
7 offerte nuove di zecca Amazon, altre a...
Una giornata di lavoro con l'IA consuma ...
'Non fate usare ChatGPT ai vostri cari':...
Un display che si allunga fino al 200% s...
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: 14:03.


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