Elimizde aşağıda yer alan ilişki tablolarının olduğunu varsayalım:

Ogrenci(ogrNo, ogrIsmi, bolum)
Ders(dersNo, dersIsmi)
Hoca(hocaNo, hocaIsmi, bolum)
DersKayit(ogrNo, dersNo, donem, yil, not)
DersVerme(hocaNo, dersNo, donem, yil)

Bilgisayar Mühendisliği bölümü hocalarının hepsi tarafından verilmiş olan derslerin isimleri nelerdir?

Eğer relational algebrada çözüm üretiyor olsaydık;

ρ(DN, (∏hocaNo,dersNo DERSVERME) / (∏hocaNo (σbolum=’BilgisayarMuhendisliği’(HOCA))))
∏dersIsmi (DN ⋈ DERS)

olacaktı. SQL’de ise bölme işlemini şu şekilde ifade etmemiz gerekiyor. Alternatif çözüm olmakla beraber aşağıdaki çözümün daha kısa ve kolay olması tercih sebebidir 😉

SELECT DISTINCT D.dersIsmi
FROM DERS D
WHERE NOT EXISTS
((SELECT DISTINCT H.hocaNo
FROM HOCA H
WHERE H.bolum = ‘BilgisayarMuhendisligi’)
EXCEPT
(SELECT DV.hocaNo
FROM DERSVERME DV
WHERE DV.dersNo = D.dersNo));

Reklamlar