Torna indietro   Hardware Upgrade Forum > Software > Programmazione

realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-04-2008, 17: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, 23: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, 23: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, 23: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, 09: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, 10: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, 10: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, 13: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 13:53.
dupa è offline   Rispondi citando il messaggio o parte di esso
Old 14-04-2008, 14: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


realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Altro che 'scandalo De Martino', in Core...
Meta leggerà i tuoi messaggi dal ...
OpenAI entra in Thrive Holdings: nasce u...
Paramount: nuovi film di Sonic e Tartaru...
EU AI Cloud, il cloud sovrano di SAP per...
God of War: la serie TV entra in pre-pro...
Stampante HP in super offerta: la multif...
Maxi offerta su Roborock S8 MaxV Ultra: ...
Ron Gilbert, il creatore di Monkey Islan...
AMD, aumento dei prezzi per i processori...
I migliori regali di Natale a meno di 50...
Sorprese post Black Friday: questi TV 4K...
NVIDIA perde quota, AMD e Intel guadagna...
Il cloud ibrido al centro delle strategi...
Amazon sorprende: avviatori, compressori...
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: 14:41.


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