Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
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
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


DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
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...
Adobe e Anthropic insieme: il nuovo Fire...
Netflix, importanti novità per l'...
Top 7 tech più venduti su Amazon ...
Stop alle app pesanti: Android 17 Beta 4...
Apple Watch Series 11 e SE 3 crollano su...
Opera Browser Connector: ChatGPT e Claud...
Nuova Opel Astra: maturità elettr...
Il film di Call of Duty ha finalmente un...
Tra nuove mappe e modalità: Battl...
Narwal Flow 2 ufficiale: 31000 Pa di asp...
GPT-Rosalind: OpenAI lancia il suo primo...
Meta aumenta i prezzi dei visori Meta Qu...
Metro 2039 annunciato con un trailer di ...
UMC aumenterà i prezzi dei wafer ...
Intel rafforza la divisione Foundry: arr...
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: 11:38.


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