Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-01-2009, 12:54   #1
Donbabbeo
Senior Member
 
L'Avatar di Donbabbeo
 
Iscritto dal: Jul 2006
Messaggi: 8152
[SQL] References su un sottoinsieme

Sto creando un database di un magazzino e sono all'ennesima revisione.
Sto in questo momento testando la funzionalità dei vincoli ma ho un dubbio su come aggiungere più vincoli sullo stesso campo.
Mi spiego meglio:

Sto facendo le prove su una versione semplificata del database solo per vedere se funzionano. Attualmente ho 3 tabelle:
una dei dipendenti(ID, Nome, Tipo [Fattorino/Magazziniere]),
una degli ordini(ID, Nome [Non ha senso lo so, ma non sapevo che metterci]) ,
una che mette in connessione le due tabelle qui sopra (id_fattorino, id_ordine)

Ovviamente SOLO i fattorini potranno far parte del possibile gruppo di dipendenti da inserire in consegna.

Il codice di creazione della tabella fatto finora è questo:
Codice:
CREATE TABLE consegna (
	id_ordine INT(3) NOT NULL,
	id_fattorino INT(3) DEFAULT '0',
PRIMARY KEY (id_ordine),
CONSTRAINT OrdCon FOREIGN KEY (id_ordine) REFERENCES ordine(id_ordine),
CONSTRAINT FatCon FOREIGN KEY (id_fattorino) REFERENCES dipendente(id_dipendente)
) ENGINE=InnoDB;
Dovrei in pratica modificare il secondo CONSTRAINT in modo che l'id_fattorino sia preso non tra tutto l'elenco degli id_dipendente, ma solo tra l'elenco degli id_dipendente il cui campo Tipo sia 'Fattorino'.

Come posso modificare la tabella per inserire questo controllo
__________________
"Quiquid Latine Dictum Sit, Altum Sonatur" 😐
Donbabbeo è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2009, 15:28   #2
Donbabbeo
Senior Member
 
L'Avatar di Donbabbeo
 
Iscritto dal: Jul 2006
Messaggi: 8152
E' un paio d'ore che ci provo, al principio ho pensato di provare tramite un trigger (se l'id dipendente inserita non è di un fattorino segnala un errore), per poi scoprire che mysql non permette trigger legati a foreign keys...

Ho quindi deciso di associare la tabella dipendenti a 2 tabelle FATTORINI e MAGAZZINIERI in cui vengono immagazzinati gli id dei dipendenti di quel tipo.

A questo punto le REFERENCES della tabella consegna invece di indirizzarle all'id_dipendente di dipendenti, le indirizzo all'id_fattorino/magazziniere di FATTORINI/MAGAZZINIERI.

A questo punto: per aggiungere automaticamente i nuovi dipendenti in uno dei 2 gruppi a seconda del tipo di mansione serve necessariamente un trigger?
__________________
"Quiquid Latine Dictum Sit, Altum Sonatur" 😐
Donbabbeo è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2009, 15:39   #3
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Nono, niente trigger, lascia perdere per favore.
Se vuoi modellare questa relazione sul database, ti consiglio di utilizzare il pattern is-a dell'SQL. (Ovvero quando si deve mappare la inheritance dei linguaggi ad oggetti in rispettive tabelle SQL)

Nel tuo caso la superclasse delle persone avrebbe tutto cio' che tutte le persone hanno
persone(ID, Nome)

poi una classe sottotipo dei fattorini, con l'identificativo e tutte le eventuali caratteristiche che i fattorini hanno (se ce ne sono)

fattorini(ID, LuogoDiPartenza, NumeroDiCartaDelSindacatoFattorini)

e poi una classe sottotipo per i magazzinieri, ciascuno con le caratteristiche che i soli magazzinieri hanno (se ce ne sono)

magazzinieri(ID, Magazzino)

tutte e 3 queste tabelle hanno solo ID come chiave primaria.
sia fattorini che magazzinieri hanno la loro ID in ForeignKey verso Persone

a questo punto ti risultera' facile forzare gli ORDINI ad avere come ID un ID solo di un fattorino, facendo puntare la foreign key verso la tabella sottotipo "magazzinieri", e non verso quella globale "persone"

Spero sia chiaro. Con un solo disegno sarebbe oltremodo banale...

Il tipo di persone non dovrebbe servirti mapparlo sul database. E' intrinseco dalla presenza della persona in una o nell'altra tabella (o entrambe?)
__________________
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.

Ultima modifica di gugoXX : 29-01-2009 alle 15:42.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2009, 16:01   #4
Donbabbeo
Senior Member
 
L'Avatar di Donbabbeo
 
Iscritto dal: Jul 2006
Messaggi: 8152
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Nono, niente trigger, lascia perdere per favore.
Se vuoi modellare questa relazione sul database, ti consiglio di utilizzare il pattern is-a dell'SQL. (Ovvero quando si deve mappare la inheritance dei linguaggi ad oggetti in rispettive tabelle SQL)

Nel tuo caso la superclasse delle persone avrebbe tutto cio' che tutte le persone hanno
persone(ID, Nome)

poi una classe sottotipo dei fattorini, con l'identificativo e tutte le eventuali caratteristiche che i fattorini hanno (se ce ne sono)

fattorini(ID, LuogoDiPartenza, NumeroDiCartaDelSindacatoFattorini)

e poi una classe sottotipo per i magazzinieri, ciascuno con le caratteristiche che i soli magazzinieri hanno (se ce ne sono)

magazzinieri(ID, Magazzino)

tutte e 3 queste tabelle hanno solo ID come chiave primaria.
sia fattorini che magazzinieri hanno la loro ID in ForeignKey verso Persone

a questo punto ti risultera' facile forzare gli ORDINI ad avere come ID un ID solo di un fattorino, facendo puntare la foreign key verso la tabella sottotipo "magazzinieri", e non verso quella globale "persone"

Spero sia chiaro. Con un solo disegno sarebbe oltremodo banale...

Il tipo di persone non dovrebbe servirti mapparlo sul database. E' intrinseco dalla presenza della persona in una o nell'altra tabella (o entrambe?)

Esattamente quello che ho fatto. Il discorso era rendere automatico l'aggiunta del dipendente alle tabelle MAGAZZINIERE e FATTORINO.
Cioè io aggiungo un nuovo dipendente (INSERT INTO dipendenti blah blah blah) a questo punto a seconda del tipo devo aggiungerlo manualmente alla tabella magazziniere o fattorino dico bene?

Perchè mi sconsigli l'uso dei trigger? E' in questo caso particolare che sono superflui o non devo proprio usarli? In alcuni punti potrei averne bisogno mi sa...
__________________
"Quiquid Latine Dictum Sit, Altum Sonatur" 😐
Donbabbeo è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2009, 16:22   #5
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da Donbabbeo Guarda i messaggi
Esattamente quello che ho fatto. Il discorso era rendere automatico l'aggiunta del dipendente alle tabelle MAGAZZINIERE e FATTORINO.
Cioè io aggiungo un nuovo dipendente (INSERT INTO dipendenti blah blah blah) a questo punto a seconda del tipo devo aggiungerlo manualmente alla tabella magazziniere o fattorino dico bene?

Perchè mi sconsigli l'uso dei trigger? E' in questo caso particolare che sono superflui o non devo proprio usarli? In alcuni punti potrei averne bisogno mi sa...
I trigger sono sconsigliati in genere solo per questioni di controllo durante le fasi di manutenzione (ma talvolta fanno casino anche durante le fasi di sviluppo)
La maggior parte delle volte che sono stati usati se ne poteva fare a meno con un buon disegno o usando altre features (check constraint etc.)

Nel tuo caso specifico, devi chiederti chi e cosa eseguira' la insert e a fronte di cosa.
Se fosse un linguaggio ad alto livello come penso, e' possibile ovviamente eseguire le 2 insert ora necessarie, per ciascun tipo di dipendente, in modo custom.
Addirittura e' possibile che il linguaggio ad alto livello abbia 2 diverse pagine per le anagrafiche di fattorini oppure di magazzinieri (tieni conto che potrebbero facilmente avrere campi diversi fra loro)
Oppure alla peggio, se proprio volessi avere un unico modo centralizzato per creare una persona indipendentemente dal suo tipo (ma quindi sarebbe proprio nell'improbabile caso che fattorini e magazzinieri avessero proprio gli stessi identici campi), al posto di strani meccanismi con trigger userei una semplice unica stored procedure.
__________________
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
 Rispondi


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
L'IA ha fatto incetta anche di processor...
Affidabilità delle GPU NVIDIA cro...
Maxi incendio in un parcheggio BYD: fiam...
Apple potrebbe diventare il terzo produt...
L'IA aiuta i computer quantistici con i ...
Nutanix Database Platform è ora i...
iliad lancia il 5G Standalone in Italia:...
Alexa+ da oggi disponibile anche in Ital...
SpaceX Starship: Ship 39 ha eseguito il ...
Auto usate: Peugeot 3008 tra le peggiori...
YMTC, il produttore di memorie 100% cine...
I gamer rinunciano alla RAM ma non agli ...
Oltre 100 estensioni Chrome malevole rub...
Multi Frame Generation 5x e 6x anche su ...
Kraken sotto ricatto dopo due accessi in...
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:22.


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