Torna indietro   Hardware Upgrade Forum > Software > Programmazione

iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-04-2008, 16:29   #1
lore_83
Member
 
Iscritto dal: Jul 2006
Messaggi: 242
[MySQL] Foreign Key quali vantaggi porta?

Ciao.
Sto imparando da poco ad usare il database mysql.
Vorrei sapere quali sono i vantaggi/svantaggi nel creare le foreign keys in una tabella, poiché non mi è chiaro il loro utilizzo.

esempio:

TABELLA CITTA

ID_CITTA
NOME
ID_NAZ
FOREIGN KEY (ID_NAZ) REFERENCES NAZIONE (ID_NAZIONE)

TABELLA NAZIONE

ID_NAZIONE
NOME

L'esempio è calzante (sintassi a parte)?
Quali vantaggi/svantaggi ho?
Le ricerche con INNER JOIN non sono indipendenti dalla presenza delle F. Keys?

Grazie e ciao.
lore_83 è offline   Rispondi citando il messaggio o parte di esso
Old 13-04-2008, 22:02   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Non ci sono vantaggi prestazionali.
E' parte dei vincoli di disegno. Se imponi quella FK tra citta' e nazione sarai SICURO sempre che ogni citta' apparterra' ad una nazione, e potrai permetterti di scrivere le query di conseguenza.
P.Es. potrai usare una INNER JOIN. Altrimenti potresti essere costretto ad usare una OUTER JOIN, proprio perche' non saresti sicuro di trovare sempre una nazione a capo di una citta'.
I vincoli e' bene che siano gestiti a livello di database. Poi sara' cura delle tue GUI, dei tuoi programmi o di quanto'altro fare in modo che non vengano violati. Ma se qualora mai venissero violati (errore di programmazione), il database rifiuterebbe le istruzioni che non li rispettano mantenendo il dati in uno stato di consistenza, che altrimenti verrebbe violata e neppure te ne accorgeresti.

Ci sono altri vincoli, non solo le FK.
Tra i principali ci sono anche i "NOT NULL" e gli "UNIQUE"
__________________
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
Old 13-04-2008, 22:16   #3
lore_83
Member
 
Iscritto dal: Jul 2006
Messaggi: 242
Ciao.

Si tratta quindi di una semplice istruzione che garantisce la relazione ad ogni città con un ed un solo record della tabella delle nazioni ed automaticamente ID_NAZ è NOT NULL.
lore_83 è offline   Rispondi citando il messaggio o parte di esso
Old 13-04-2008, 22:49   #4
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da lore_83 Guarda i messaggi
Ciao.

Si tratta quindi di una semplice istruzione che garantisce la relazione ad ogni città con un ed un solo record della tabella delle nazioni ed automaticamente ID_NAZ è NOT NULL.
non e' automaticamente NOT NULL, meglio forzarglielo se ti serve.
__________________
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
Old 14-04-2008, 08:17   #5
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Quoto tutto quanto detto da gugoXX, in più ti consiglio anche di mettere un indice sulle FK. Non so con mysql (in particolare con innoDB, immagino tu stia utilizzando quel meccanismo e non MyISAM che credo manco le supporti le FK...lol!), ma in oracle gli indici sulle fk servono per evitare il table lock e usare invece il row lock...se mi ricordo bene...
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 14-04-2008, 09:24   #6
lore_83
Member
 
Iscritto dal: Jul 2006
Messaggi: 242
Quote:
...in più ti consiglio anche di mettere un indice sulle FK...
Cioè mettere INDEX() su ID_NAZIONE nella tabella NAZIONI?

Quote:
...gli indici sulle fk servono per evitare il table lock e usare invece il row lock...
E per uno che non sa nemmeno cosa sia questo problema?

PS: se inserissi un valore ID_NAZ non esistente in ID_NAZIONE il db mi darebbe errore, corretto?

Grazie comunque, davvero rapidi ed utili.
lore_83 è offline   Rispondi citando il messaggio o parte di esso
Old 14-04-2008, 09:29   #7
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Quote:
Originariamente inviato da lore_83 Guarda i messaggi
Cioè mettere INDEX() su ID_NAZIONE nella tabella NAZIONI?
No, quella è la PK della tabella NAZIONI e l'indice unique dovrebbe venir da sè (spero! comunque ci vuole.)

Io dico l'indice su ID_NAZ nella tabella CITTA.

Quote:
E per uno che non sa nemmeno cosa sia questo problema?
Devi guardare sul manuale...non conosco MySQL cosi a fondo. Ma se hai un numero di righe esigue, non è un grosso problema quello del lock a livello di riga o di tabella.

Quote:
PS: se inserissi un valore ID_NAZ non esistente in ID_NAZIONE il db mi darebbe errore, corretto?

Grazie comunque, davvero rapidi ed utili.
Si esatto.
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 14-04-2008, 12:48   #8
dupa
Senior Member
 
L'Avatar di dupa
 
Iscritto dal: Jan 2002
Città: Napoli
Messaggi: 1727
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Non ci sono vantaggi prestazionali.
E' parte dei vincoli di disegno. Se imponi quella FK tra citta' e nazione sarai SICURO sempre che ogni citta' apparterra' ad una nazione, e potrai permetterti di scrivere le query di conseguenza.
P.Es. potrai usare una INNER JOIN. Altrimenti potresti essere costretto ad usare una OUTER JOIN, proprio perche' non saresti sicuro di trovare sempre una nazione a capo di una citta'.
I vincoli e' bene che siano gestiti a livello di database. Poi sara' cura delle tue
Non mi pare sia come tu dici.
Una colonna FK potrebbe essere tranquillamente NULL, quind iil tuo discorso sulle JOIN cade.

Cmq i grossi vantaggi delle FK sono le ON UPDATE, ON DELETE.
__________________
Se buttassimo in un cestino tutto ciò che in Italia non funziona cosa rimarrebbe? Il cestino.

Ultima modifica di dupa : 14-04-2008 alle 12:53.
dupa è offline   Rispondi citando il messaggio o parte di esso
Old 14-04-2008, 13:20   #9
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Non ci sono vantaggi prestazionali.
E' parte dei vincoli di disegno. Se imponi quella FK tra citta' e nazione sarai SICURO sempre che ogni citta' apparterra' ad una nazione, e potrai permetterti di scrivere le query di conseguenza.
P.Es. potrai usare una INNER JOIN. Altrimenti potresti essere costretto ad usare una OUTER JOIN, proprio perche' non saresti sicuro di trovare sempre una nazione a capo di una citta'.
I vincoli e' bene che siano gestiti a livello di database. Poi sara' cura delle tue GUI, dei tuoi programmi o di quanto'altro fare in modo che non vengano violati. Ma se qualora mai venissero violati (errore di programmazione), il database rifiuterebbe le istruzioni che non li rispettano mantenendo il dati in uno stato di consistenza, che altrimenti verrebbe violata e neppure te ne accorgeresti.

Ci sono altri vincoli, non solo le FK.
Tra i principali ci sono anche i "NOT NULL" e gli "UNIQUE"
Concordo: l'integrità referenziale serve a mantenere consistenti (almeno per questa parte) i dati. E visto che i database devono gestire dati...
Quote:
Originariamente inviato da shinya Guarda i messaggi
Quoto tutto quanto detto da gugoXX, in più ti consiglio anche di mettere un indice sulle FK. Non so con mysql (in particolare con innoDB, immagino tu stia utilizzando quel meccanismo e non MyISAM che credo manco le supporti le FK...lol!), ma in oracle gli indici sulle fk servono per evitare il table lock e usare invece il row lock...se mi ricordo bene...
Mumble. Strano. Indicando un constraint di FOREING KEY generalmente viene sempre creato un indice per il campo che ne fa uso.
Quote:
Originariamente inviato da dupa Guarda i messaggi
Non mi pare sia come tu dici.
Una colonna FK potrebbe essere tranquillamente NULL, quind iil tuo discorso sulle JOIN cade.

Cmq i grossi vantaggi delle FK sono le ON UPDATE, ON DELETE.
Il discorso fondamentale è che i dati siano consistenti, e quanto scritto da "gugo" va benissimo anche nel caso in cui la colonna in oggetto accetti NULL come "valore".

E' chiaro, comunque, che con un valore NULL la JOIN non potrà eseguire il "match".
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
Disney+ cambia: arriva Hulu, ma il servi...
Google annuncia Gemini Enterprise: l'IA ...
Battlefield 6 debutta tra code infinite ...
Gli iPhone di seconda mano dominano il m...
Pavel Durov (Telegram) lancia l'allarme:...
Occhiali Smart come lo smartphone: il fu...
Arriva NVIDIA GB300 NVL72, il cluster di...
Copilot si collega a OneDrive, Gmail e D...
Il Liquid Glass di iOS 26 è stato...
I biocarburanti fanno più danni d...
ELF, il Frankenstein di Mercedes che ant...
Da Kia arriva il passaporto per le batte...
The Elder Scrolls 6 renderà omagg...
YouTube dà una 'seconda chance' a...
Attacco hacker a Oracle E-Business Suite...
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: 01:02.


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