Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-05-2011, 17:33   #1
diego86
Senior Member
 
L'Avatar di diego86
 
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
diego86 è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2011, 20:40   #2
MarcioPG
Member
 
L'Avatar di MarcioPG
 
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
MarcioPG è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2011, 21:22   #3
diego86
Senior Member
 
L'Avatar di diego86
 
Iscritto dal: Mar 2004
Città: Milano
Messaggi: 415
uso postgresql
__________________
Ho concluso con Worp, -V3G3TA-, Marco911, TheDragon81, ciociola
------------------------------------------------
Diego
diego86 è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2011, 16:50   #4
Die1380
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?
Die1380 è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2011, 17:02   #5
MarcioPG
Member
 
L'Avatar di MarcioPG
 
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
MarcioPG è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Intel prepara 'Raptor Lake Next'? Nel 20...
Una telefonata del CEO di Amazon dietro ...
Grazie a GLIMPSE-17775 il telescopio spa...
Samsung Galaxy A27 5G è ufficiale...
TCL aggiorna la sua gamma di monitor per...
Anche OPPO avrà uno smartphone co...
La Radeon RX 9070 XT appare su Steam e m...
L'America si ribella ai datacenter: bloc...
'Artificial General Engineer': l'IA di J...
Il drone NASA Dragonfly, che voler&agrav...
Stop immediato a Fable 5 e Mythos 5: il ...
"Prime Day Amazon il 23-26 giugno": sì e...
Oggi 2 super MacBook Pro M5 e M5 Pro, 24...
Tineco Floor One Station S9 Artist: il s...
Raggiunte nuove altitudine e velocit&agr...
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:43.


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