Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Abbiamo provato per molti giorni il nuovo Z Fold7 di Samsung, un prodotto davvero interessante e costruito nei minimi dettagli. Rispetto al predecessore, cambiano parecchie cose, facendo un salto generazionale importante. Sarà lui il pieghevole di riferimento? Ecco la nostra recensione completa.
The Edge of Fate è Destiny 2.5. E questo è un problema
The Edge of Fate è Destiny 2.5. E questo è un problema
Bungie riesce a costruire una delle campagne più coinvolgenti della serie e introduce cambiamenti profondi al sistema di gioco, tra nuove stat e tier dell’equipaggiamento. Ma con risorse limitate e scelte discutibili, il vero salto evolutivo resta solo un’occasione mancata
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello
AMD ha aggiornato l'offerta di CPU HEDT con i Ryzen Threadripper 9000 basati su architettura Zen 5. In questo articolo vediamo come si comportano i modelli con 64 e 32 core 9980X e 9970X. Venduti allo stesso prezzo dei predecessori e compatibili con il medesimo socket, le nuove proposte si candidano a essere ottimi compagni per chi è in cerca di potenza dei calcolo e tante linee PCI Express per workstation grafiche e destinate all'AI.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2010, 17:49   #1
Xizor
Member
 
L'Avatar di Xizor
 
Iscritto dal: Dec 2006
Messaggi: 185
[MySql] Dubbio foreign Key

Salve a tutti è da poco che metto le mani su MySql, sto provando a capire qualcosa riguardo le Query fra tabelle effettuabili grazie alle foreign key.

Se io creo due tabelle, Artista e Canzone e in Canzone ci metto una chiave esterna che fa riferimento all'artista posso fare una cosa del genere? :

select Titolo from Canzone where Artista.Nome='Nomeartista';

Cioè vorrei farmi dare in output tutti i titoli delle canzoni che l'artista ha fatto, dando in input il suo nome.


Ho provato ma mi dice ERROR 1109 : Tabella 'artisti' sconosciuta in where clause.

Cosa ho sbagliato? Grazie mille!
Xizor è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2010, 18:49   #2
vegeta83ssj
Senior Member
 
L'Avatar di vegeta83ssj
 
Iscritto dal: Feb 2002
Città: Modena
Messaggi: 592
Quello che intendi fare tu si realizza con un JOIN.
Le foreign key servono a garantire in un certo senso l'integrità dei dati.
Nel tuo esempio, una foreign key sul nome dell'artista ti impedisce di inserire canzoni di artisti il cui nome non è presente nella tabella artista.

Ciauz
vegeta83ssj è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2010, 23:02   #3
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Il concetto di chiave esterna è un vincolo di integrità abbastanza importante:
pensa ad esempio ad un DB contenente le informazioni sulle immatricolazioni automobilistiche con almeno 2 tabelle AUTO e PROPRIETARI

La prima oltre ai dati peculiari avrà un riferimento all' id del proprietario che costituisce appunto la chiave esterna ed assicura che in ogni momento a partire dalla targa dell' auto sia possibile identificarne il proprietario, se cosi non fosse avremmo auto fantasma.
La chiave esterna comporta quindi che in fase di inserimento di un' auto dovremmo avere la corrispondente tupla per il proprietario e questo non può essere rimosso se ha ancora almeno un' auto intestata.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2010, 09:29   #4
Xizor
Member
 
L'Avatar di Xizor
 
Iscritto dal: Dec 2006
Messaggi: 185
Ah ok, quindi il concetto di chiave esterna mi serve soltanto per garantire l'integrità dei dati soprattutto, giusto?

Quindi se io provo a cancellare un artista, il cui ID è chiave esterna in "Canzone", se ha scritto almeno una canzone, non lo posso cancellare per il concetto di integrità dei dati.

Ho provato e mi dice:

ERRORE 1217 : Impossibile cancellare la riga: un vincolo di integrità referenziale non è soddisfatto.

E' questo quello che intendi tu?

Ultima modifica di Xizor : 17-02-2010 alle 09:35.
Xizor è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2010, 11:52   #5
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
certo
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2010, 13:47   #6
francesco832003
Junior Member
 
Iscritto dal: Jun 2007
Messaggi: 8
Quote:
Originariamente inviato da Xizor Guarda i messaggi
Salve a tutti è da poco che metto le mani su MySql, sto provando a capire qualcosa riguardo le Query fra tabelle effettuabili grazie alle foreign key.

Se io creo due tabelle, Artista e Canzone e in Canzone ci metto una chiave esterna che fa riferimento all'artista posso fare una cosa del genere? :

select Titolo from Canzone where Artista.Nome='Nomeartista';

Cioè vorrei farmi dare in output tutti i titoli delle canzoni che l'artista ha fatto, dando in input il suo nome.


Ho provato ma mi dice ERROR 1109 : Tabella 'artisti' sconosciuta in where clause.

Cosa ho sbagliato? Grazie mille!

Ciao,
per fare quello che dici tu dovresti mettere in join le due tabelle:

select c.Titolo from Canzoni c, Artista a where c.uidartista = a.uidartista and a.Nomeartista = 'NomeArtista'

Nella join in grassetto ci va il vincolo di fk
francesco832003 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy Z Fold7: un grande salto generazionale Recensione Samsung Galaxy Z Fold7: un grande sal...
The Edge of Fate è Destiny 2.5. E questo è un problema The Edge of Fate è Destiny 2.5. E questo ...
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello Ryzen Threadripper 9980X e 9970X alla prova: AMD...
Acer TravelMate P4 14: tanta sostanza per l'utente aziendale Acer TravelMate P4 14: tanta sostanza per l'uten...
Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque Hisense M2 Pro: dove lo metti, sta. Mini proiett...
Sconti nuovi di zecca su Amazon: 27 arti...
Un'esplorazione del 'lato oscuro' di Fac...
Apple ha venduto 3 miliardi di iPhone da...
Grandi sconti oggi sugli spazzolini elet...
Reddit sfida Google: vuole diventare il ...
Nuovi sconti super mini PC: Ryzen 7, 32G...
Addio NATO, benvenuta PAX ARMATA: tutto ...
Opportunità di guadagno: Microsof...
Proton non si ferma e lancia un nuovo au...
Acer TravelMate P4 14 con AMD Ryzen PRO:...
Dopo Aruba e Infocert, anche Register.it...
Fai da te: trapani avvitatori a doppia b...
Microsoft può stappare lo champag...
Amazon vola a 167,7 miliardi nel Q2: i n...
Meglio il robot Lefant M330Pro a 104€ o ...
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:46.


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