|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Apr 2004
Città: La regione del Triplete
Messaggi: 5749
|
[SQL] mi aiutate con la query?
Ho un DB con questo schema:
Cliente(id, cognome, nome). Pk id Album(titolo, cantante, genere) pk titolo Cassetta(id, titolo) pk id CD(id, titolo) pk id Acquisto(idcdocas, cliente, dataacq) pk idcdocas cliente dataacq Per semplicità ammetto che il titolo delle canzoni sia univoco e ho solo il titolo come chiave. Devo trovare, tra tutti quelli che hanno comprato un album sia di blues sia di jazz, i clienti che hanno comprato solo cassette di jazz e solo CD di blues. Per ora sono riuscito, lavorando sulla tabella acquisto, CD e cassetta, a trovare, via intersezione, i clienti che hanno comprato sia di blues che di jazz... ne ho fatto una vista. Ora come trovo quelli richiesti? Inviato dal mio ASUS Transformer Pad TF300T con Tapatalk 2
__________________
Trattative felicemente concluse con domienico120, xbax88 ed engiel, ottimi e seri utenti. |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
|
Sì ma così fa cacare... e se un cd e una cassetta hanno lo stesso id? Non puoi fare una tabella "Supporto" con (id, titolo, formato), dove formato può essere CD/Cassetta?
__________________
-> The Motherfucking Manifesto For Programming, Motherfuckers |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Apr 2004
Città: La regione del Triplete
Messaggi: 5749
|
Credo che stia proprio lì la difficoltà dell'esercizio..
Sulle chiavi credo che sia sottinteso che bluray e DVD abbiano id differenti tipo br01 e d09. Inviato dal mio ASUS Transformer Pad TF300T con Tapatalk 2
__________________
Trattative felicemente concluse con domienico120, xbax88 ed engiel, ottimi e seri utenti. |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Apr 2004
Città: La regione del Triplete
Messaggi: 5749
|
Credo di aver trovato la soluzione:
I clienti che hanno comprato una cassetta di jazz si trovano nell'insieme di quelli che hanno comprato una cassetta di jazz e nello stesso tempo NON si trovano nell'insieme di quelli che hanno comprato un cd di jazz. Allo stesso modo i clienti che hanno comprato un cd di blues si trovano nell'insieme di quelli che hanno comprato un cd di blues e nello stesso tempo NON si trovano nell'insieme di quelli che hanno comprato una cassetta di blues. L'intersezione tra i due insiemi ottenuti restituisce i clienti che hanno comprato solo cassette di jazz e solo cd di blues, tra quelli che hanno comprato dischi di quei due generi indipendentemente dal formato selezionati con la vista di cui parlavo sopra. Riporto il codice così mi dite se è tutto giusto: La vista Codice:
create view clientientrambiigeneri (codice) as (select cliente from acquisto a inner join cd on a.idcdocas = cd.id inner join album al on cd.titolo = al.titolo where al.genere = "blues" intersect select cliente from acquisto a inner join cassetta c on a.idcdocas = c.id inner join album al on c.titolo = al.titolo where al.genere = "jazz" ) Codice:
select c.id, c.cognome, c.nome from cliente c inner join clientientrambiigeneri g on c.id = g.codice where g.codice in (select n.cliente from acquisto a inner join cassetta c on a.idcocas = c.id inner join album al on c.titolo = al.titolo where al.genere = "jazz") and g.codice not in (select n.cliente from acquisto a inner join cd on a.idcocas = cd.id inner join album al on cd.titolo = al.titolo where a.-genere = "jazz") intersect select c.id, c.cognome, c.nome from cliente c inner join clientientrambiigeneri g on c.id = g.codice where g.codice in (select n.cliente from acquisto a inner join cd on a.idcocas = cd.id inner join album al on cd.titolo = al.titolo where al.genere = "blues") and g.codice not in (select n.cliente from acquisto a inner join cassetta c on a.idcocas = c.id inner join album al on c.titolo = al.titolo where al.genere = "blues")
__________________
Trattative felicemente concluse con domienico120, xbax88 ed engiel, ottimi e seri utenti. |
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2782
|
Non so se è giusto...
Codice:
(
select Acquisto.cliente
from Acquisto inner join CD on Aquisto.idcdocas = CD.id
inner join Album on CD.titolo = Album.titolo
where Album.genere = "blues"
intersect
select Acquisto.cliente
from Acquisto inner Cassetta on Aquisto.idcdocas = Cassetta.id
inner join Album on Cassetta.titolo = Album.titolo
where Album.genere = "jazz"
)
except
(
select Acquisto.cliente
from Acquisto inner join CD on Aquisto.idcdocas = CD.id
inner join Album on CD.titolo = Album.titolo
where Album.genere = "jazz"
union
select Acquisto.cliente
from Acquisto inner Cassetta on Aquisto.idcdocas = Cassetta.id
inner join Album on Cassetta.titolo = Album.titolo
where Album.genere = "blues"
)
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 14:56.




















