Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2010, 18: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, 19: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 17-02-2010, 00: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, 10: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 10:35.
Xizor è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2010, 12: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, 14: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 Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
La serie POCO X8 Pro è pronta al ...
Smartphone: 2026 difficile per il mercat...
Star Wars: Knights of the Old Republic R...
Huang, NVIDIA: OpenClaw ha realizzato in...
Annunciano il recupero di 4,8 milioni di...
Oggi degli ottimi auricolari Sony con ca...
Muffa in casa? Questo deumidificatore da...
Sonos Era 100: il punto d'ingresso per u...
"Non stiamo sostituendo nessuno con...
Tutti i robot in offerta ora: prezzi bas...
Fra 3 giorni, a mezzanotte, Amazon attiv...
Il principale limite del MacBook Neo &eg...
899€ in tutti i colori, crolla il prezzo...
Sempre più pubblicità su Y...
Costo della memoria alle stelle? Non ave...
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: 15:56.


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