|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Mar 2004
Città: Milano
Messaggi: 415
|
[database] progettazione logica relazione 1-n
ciao a tutti...
devo realizzare un db con una relazione 1-n e mi è venuto un dubbio su una cosa elementare. Prendiamo come esempio (che calza a pennello su ciò che serve a me) la classica relazione mamma-figli dove ogni mamma può avere più figli, ma in quanto mamma deve averne almeno uno. MAMMA(codice, nome, cognome) FIGLIO(codice, nome, cognome, codicemamma) io farei una cosa del genere... Però facendo così è possibile che una mamma inserita nel db non abbia nessun figlio che si riferisca a lei, che invece è proprio la cosa che mi devo assicurare che ci sia...come devo fare??? ESEMPIO: MAMMA 1 anna rossi 2 maria bianchi 3 pina verdi FIGLIO 1 luca gialli 1 2 mario blu 2 3 paolo neri 2 In questo caso io DEVO assicurarmi che per ogni mamma inserita ci sia almeno un figlio, quindi anche la signora pina verdi deve avere un figlio inserito...come faccio a mettere questo vincolo?
__________________
Ho concluso con Worp, -V3G3TA-, Marco911, TheDragon81, ciociola ------------------------------------------------ Diego |
|
|
|
|
|
#2 |
|
Member
Iscritto dal: Jul 2005
Città: Perugia
Messaggi: 132
|
Dunito sia possibile farlo a livello di struttura dati del DB:
Se attivi l'integrità referenziale (foreign key) sulla tabella figli prima di crearne uno nuovo devi tassativamente prima aver creato la mamma, e quindi una mamma nel momento in cui viene inserita ovviamente non avrà figli esistenti... L'unica strada forse potrebbe essere utilizzare un trigger sull'update, creazione e delete di un figlio che controlli che non ci siano mamme orfane e nel caso blocchi l'operazione: così facendo nel momento in cui si crea una nuova mamma il figlio successivo inserito nel DB deve tassativamente essere di quell'ultima mamma e non si possono modificare o cancellare "figli unici" lasciando madri "orfane"... la effettiva fattibilità e l'implementazione dipende molto dall'engine che usi... quale è?
__________________
Main: i7-3770K · Corsair H60 · MSI GTX 580 Twin Frozr II OC · Asus Maximus V Gene mATX · Corsair Vengeance 1600Mhz CL8 16GB · Samsung 840 EVO 500GB + Crucial C300 256Gb · Plextor PX-L890SA · Seasonic X850 · Corsair Obsidian 350D · Iiyama ProLite B24D9HDS Muletto: Q6600 G0/Scythe Ninja Plus · Radeon HD5850 · Asus P5E · HDs X-25M G2 160Gb, Seagate 7200.11 500Gb · Corsair VX 550 · Cooler Master CM-690 HTPC: Atom D525,ION-2,3GB RAM,64GB SSD |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Mar 2004
Città: Milano
Messaggi: 415
|
uso postgresql
__________________
Ho concluso con Worp, -V3G3TA-, Marco911, TheDragon81, ciociola ------------------------------------------------ Diego |
|
|
|
|
|
#4 |
|
Junior Member
Iscritto dal: May 2011
Messaggi: 9
|
Uhmmmm... non capisco a cosa ti possa servire un giro così contorto di controlli... è logico che l'integrità referenziale verrà testata quando inserisci un record Figlio il quale deve per forza corrispondere ad un record Madre.
Ma se inserisci una nuova Madre? Se il DB al momento fosse vuoto, il primo inserimento quale sarebbe? Certo puoi fare tutto un giro di trigger per inserire sempre un Figlio fittizio all'inserimento di una Madre e trigger che impediscano la cancellazione dei Figli unici... ma ancora una volta mi chiedo a cosa possa servire... forse deve ripensare a quello che vuoi fare prima di infilarti in una strada stretta e contorta... non ti basta semplicemente mettere tutti in unico record? |
|
|
|
|
|
#5 |
|
Member
Iscritto dal: Jul 2005
Città: Perugia
Messaggi: 132
|
effettivamente anche seguendo l'ipotesi del trigger sulla tabella figli andresti incontro a rogne: ad esempio potresti bloccare del tutto il sistema inserendo due "madri" di fila dato che a quel punto inserendo un figlio avresti comunque una madre "orfana".....
__________________
Main: i7-3770K · Corsair H60 · MSI GTX 580 Twin Frozr II OC · Asus Maximus V Gene mATX · Corsair Vengeance 1600Mhz CL8 16GB · Samsung 840 EVO 500GB + Crucial C300 256Gb · Plextor PX-L890SA · Seasonic X850 · Corsair Obsidian 350D · Iiyama ProLite B24D9HDS Muletto: Q6600 G0/Scythe Ninja Plus · Radeon HD5850 · Asus P5E · HDs X-25M G2 160Gb, Seagate 7200.11 500Gb · Corsair VX 550 · Cooler Master CM-690 HTPC: Atom D525,ION-2,3GB RAM,64GB SSD |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 04:22.



















