GROUP BY HAVING ORDER BY LIMIT

Slides:



Advertisements
Benzer bir sunumlar
VTYS 2012 Mehmet Emin KORKUSUZ Ders - 05.
Advertisements

Hazırlayan : Öğr. Gör. Fahri YILMAZ
distinct ile group by komutlarının özellikleri ve farkları
SQL Structured Query Language
Verileri gruplayarak analiz
KARMAŞIK SORGULAR.
KARMAŞIK SORGULAR.
SQL (Structured Query Language)
SQL Structured Query Language (Yapısal sorgulama dili)
En ucuzundan en pahalısına doğru sıralanmış olarak “Cep Telefonları” kategorisindeki tüm ürünlerin isimleri “Spor” kategorisinde ürünleri listelenen “İstanbul”
Karmaşık (İç içe) SELECT Sorguları
SQL KOMUTLARI.
SQL Komutlar 2 Sibel SOMYÜREK.
Veri Tabanı I.
Veritabanı Yönetim Sistemleri-I
Alt Sorgular Veritabanı 2.
5 Sorgulama İşlemleri Veritabanı 1.
Tek Tablo İçinde Sorgulamalar
SQL Sorgu Örnekleri.
VeriTabanı Uygulama. Tabloları yaratmak için MySQL komutları.
BÖLÜM 6 SQL SERVER KOMUTLARI.
10 Gruplandırarak Sorgulama
SQL (STRUCTURED QUERY LANGUAGE)
Departman ve Personel Tablosu Soruları
ÖRNEKLER. musteri Id adi soyadi mus_satis Id barkod adet Urunlar barkod urun_adi kodu fiyati Stok_hareket tarih barkod gelen giden.
VTYS Öğr. Gör. Engin DUTAR
SQL’e Giriş ve SELECT Komutu
GÖRÜNÜŞLER (VİEWS). Görünüş Temel tablolar üzerinde yeni bir tablo almak için yapılan işlemlerin sonucu Sanal tablo- gerçekten veri tabanında yoktur ve.
MySQL Operatörleri ve Fonksiyonları
SQL SERVER 2008 Yücel YILDIRIM.
VeriTabanı Uygulama.
Varlık-İlişki Modeli (E-R Modeli)
SQL Sibel SOMYÜREK.
SQL Komutları (2) Uzm. Murat YAZICI.
FONKSİYONLAR İbrahim Onur Sığırcı.
RAISE RECORD/CURSOR TRIGGER
VTYS Öğr. Gör. Engin DUTAR
K ıSıT -V ıEW -S EQUENCE U NıON -I NTERSECTıON -E XCEPT E XıSTS -I N İbrahim Onur Sığırcı.
C OMPANY DB / Ö RNEKLER İbrahim Onur Sığırcı. İ LIŞKI T ABLOLARı idfnamelnamebdate AhmetDemir MehmetBakır AyşeTunç1994.
Veri Tabanı Yönetimi Dersi 7. Laboratuvarı Arş. Gör. Pınar CİHAN.
Veri Tabanı Yönetimi Dersi 8. Laboratuvarı Arş. Gör. Pınar CİHAN.
S ORGU / DML / DDL KOMUTLARı İbrahim Onur Sığırcı.
Veri Tabanı Yönetimi Dersi 2. Laboratuvarı Arş. Gör. Pınar CİHAN.
Veri Tabanı Yönetimi Dersi 4. Laboratuvarı Arş. Gör. Pınar CİHAN.
ÖTÖ 451 Okul Yönetiminde Bilgisayar Uygulamaları R. Orçun Madran.
Yapısal Sorgulama Dili SQL Hafta 7. TEKRARLI SATIRLARI ÖNLEMEK  DISTINCT komutu ile sorgu sonucunda birden fazla kayıt aynı verileri içeriyorsa tekrarlı.
GROUP BY HAVING ORDER BY İbrahim Onur Sığırcı. Ö RNEK 1 – G RUP F ONKSIYONLARı * «Sales» departmanında kaç kişinin çalıştığını, toplam maaşlarını, en.
ÖTÖ 451 Okul Yönetiminde Bilgisayar Uygulamaları R. Orçun Madran.
Veri Tabanı Yönetimi Dersi 1. Laboratuvarı Arş. Gör. Pınar CİHAN.
Veri Tabanı Yönetimi Dersi 4. Laboratuvarı Constraint-View-Sequence Union-Intersection-Except Exısts-In Arş. Gör. Pınar CİHAN.
Veri Tabanı Yönetimi Dersi 5
Veri Tabanı Yönetimi Dersi 7. Laboratuvarı
© Marmara Üniversitesi Uzaktan Eğitim Uygulama ve Araştırma Merkezi
Veri Tabanı Yönetimi Dersi 8. Laboratuvarı
© Marmara Üniversitesi Uzaktan Eğitim Uygulama ve Araştırma Merkezi
© Marmara Üniversitesi Uzaktan Eğitim Uygulama ve Araştırma Merkezi
© Marmara Üniversitesi Uzaktan Eğitim Uygulama ve Araştırma Merkezi
VERİ TABANI SQL (STRUCTURED QUERY LANGUAGE) SAVAŞ TUNÇER.
© Marmara Üniversitesi Uzaktan Eğitim Uygulama ve Araştırma Merkezi
Company DB / Örnekler İbrahim Onur Sığırcı.
© Marmara Üniversitesi Uzaktan Eğitim Uygulama ve Araştırma Merkezi
SQL GROUP BY HAVING.
FONKSİYONLAR İbrahim Onur Sığırcı.
Sorgu / dml / ddl komutları
RAISE RECORD/CURSOR TRIGGER
SQL (STRUCTURED QUERY LANGUAGE)
FONKSİYONLAR- Metin Fonksiyonları
VERİTABANI YÖNETİM SİSTEMLERİ 6-SQL Server-4-DML
Intersect Tablo1 Sno Ad Soyad 1 Ali Ak 2 Veli Kara 3 Can Mor Tablo2
SQL VIEW.
Sunum transkripti:

GROUP BY HAVING ORDER BY LIMIT İbrahim Onur Sığırcı

Örnek 1 – Grup Fonksiyonları * «Sales» departmanında kaç kişinin çalıştığını, toplam maaşlarını, en yüksek maaşı, en düşük maaşı ve ortalama maaşı bulunuz. SELECT count(*), sum(salary), max(salary), min(salary), avg(salary) FROM department d, employee e WHERE d.dnumber = e.dno AND d.dname = ‘Sales’

Örnek 2 – Grup Fonksiyonları * 8 numaralı departmanda çalışan işçilerin ortalama ve toplam maaşlarını bulunuz. SELECT avg(salary), sum(salary) FROM employee e WHERE e.dno = 8 avg(salary) sum(salary) 40821 571500

Örnek 2 – Grup Fonksiyonları * 8 numaralı departmanda çalışan işçilerin ortalama ve toplam maaşlarını bulunuz. SELECT avg(salary) AS ortalama, sum(salary) AS toplam FROM employee e WHERE e.dno = 8 ortalama toplam 40821 571500

Örnek 3 – Grup Fonksiyonları * «Middleware» projesinde kaç kişinin çalıştığını ve bu çalışanların ortalama maaşlarını bulunuz. SELECT count(*) AS calisan_sayisi, avg(salary) FROM employee e, works_on w, project p WHERE e.snn = w.essn AND w.pno = p.pnumber AND p.pname = ‘Middleware’

GROUP BY Gruplamalar yapıp, grup fonksiyonlarını kullanmayı sağlar. code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 SELECT count(*) FROM take GROUP BY code code id BLM1551 12501105, 15011607, 12011031 BLM1541 12011031, 12011067 EEM2501 12501105 BLM3561 15011607 EEM4581 12011067, 13011705 count(*) 3 2 1

GROUP BY SELECT count(*), code FROM take WHERE code LIKE ‘BLM%’ GROUP BY code code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 BLM3561 code id BLM1551 12501105, 15011607, 12011031 BLM1541 12011031, 12011067 BLM3561 15011607 count(*) code 3 BLM1551 2 BLM1541 1 BLM3561

ORDER BY Sorguları belli bir sıraya göre yazdırmayı sağlar. SELECT code, id FROM take WHERE id LIKE ‘12%’ ORDER BY id code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 code id BLM1551 12011031 BLM1541 12011067 EEM4581 12501105 EEM2501

ORDER BY SELECT code, id FROM take WHERE id LIKE ‘12%’ ORDER BY id DESC code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 code id BLM1551 12501105 EEM2501 BLM1541 12011067 EEM4581 12011031

ORDER BY SELECT code, id FROM take ORDER BY id DESC, code ASC code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 code id BLM1551 15011607 BLM3561 EEM4581 13011705 12501105 EEM2501 BLM1541 12011067 12011031

Örnek 4 * Her bir projede çalışanların ortalama maaşını bulup proje ismine göre alfabetik olarak sıralayınız. SELECT pname, avg(salary) FROM employee e, works_on w, project p WHERE e.snn = w.essn AND w.pno = p.pnumber GROUP BY pname ORDER BY pname

Örnek 5 * Her bir departmanda her bir cinsiyetten kaçar işçi olduğunu ve bu işçilerin ortalama maaşlarını bulunuz. SELECT dno, sex, count(*), avg(salary) FROM employee e GROUP BY dno, sex

Örnek 5 * Her bir departmanda her bir cinsiyetten kaçar işçi olduğunu ve bu işçilerin ortalama maaşlarını bulunuz. SELECT dno AS departman_no, sex AS cinsiyet, count(*) AS calisan_sayisi, avg(salary) AS ortalama_maas FROM employee e GROUP BY dno, sex

HAVING Gruplama için şart eklemeye yarar. SELECT code, id FROM take WHERE id LIKE ‘12%’ GROUP BY code HAVING count(*)=1 code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 code id BLM1551 12011031 BLM1541 12011067 EEM4581 12501105 EEM2501 code id BLM1551 12011031, 12501105 BLM1541 12011031, 12011067 EEM4581 12011067 EEM2501 12501105 code id EEM4581 12011067 EEM2501 12501105

Örnek 6 * 5 numaralı departman dışındaki departmanlar arasından, ortalama maaşı 40000$’dan fazla olan departmanların numaralarını ve bu departmandaki ortalama maaşları bulan sorguyu yazınız. SELECT dno AS departman_no, avg(salary) AS ortalama_maas FROM employee GROUP BY dno HAVING avg(salary) > 40000 AND dno<>5

LIMIT Sorgu sonucundaki oluşan tabloda belli bir aralıktaki satırları almak için kullanılır. code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 SELECT code, id FROM take LIMIT 3 code id BLM1551 12501105 15011607 12011031

LIMIT SELECT code, id FROM take LIMIT 3 OFFSET 5 code id code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 SELECT code, id FROM take LIMIT 3 OFFSET 5 code id EEM2501 12501105 BLM3561 15011607 EEM4581 12011067

LIMIT SELECT code, id FROM take LIMIT 5, 3 code id code id BLM1551 12501105 15011607 12011031 BLM1541 12011067 EEM2501 BLM3561 EEM4581 13011705 SELECT code, id FROM take LIMIT 5, 3 code id EEM2501 12501105 BLM3561 15011607 EEM4581 12011067

LIMIT LIMIT A LIMIT B, A LIMIT A OFFSET B İlk A tanesi B numaralı kayıttan sonra (hariç) A satır LIMIT A OFFSET B A adet satır B numaralı kayıttan sonra (hariç)

ÖRNEK 7 En çok maaşı alan işçinin ismini ve soyismini gösteren sorguyu yazınız. SELECT fname, lname FROM employee ORDER BY salary DESC LIMIT 1 veya LIMIT 0, 1 LIMIT 1 OFFSET 0