Visual Basic 2000
SQL (Veritabanı Sorgulama Dili)
Açıklama ve Örnekler
INDEX
1.TEK TABLODAN SORGULAMALAR
---SELECT * FROM Tablo
---SELECT * DISTINCT FROM Tablo
2.TABLO BİLGİLERİNİN SIRALANMIŞ OLARAK LİSTELENMESİ
---ORDER BY
---ORDER BY ASC DSC
3.BİRDEN ÇOK ALANA GÖRE SIRALAMA
---SELECT alan1, alan2 FROM Tablo ORDER BY alan1
---KOŞULA BAGLI OLARAK LISTELEME
-----WHERE
---KARŞILAŞTIRMA OPERATÖRLERi
-----ÇEŞITLI VERI TIPLERI IÇIN BASIT SORGULAMALAR
---------1.NÜMERİK VERİ TİPLERİ
---------2.KARAKTER VERİ TİPLERİ (CHAR)
---------3.TARİH VERİ TİPİ (DATE)
---------4.MANTIKSAL VERİ TİPİ
4.BİRDEN ÇOK KOŞULA DAYALI SORGULAMALAR (NOT / AND / OR)
---BİR VERİ KÜMESİNDE ARAMA -IN OPERATÖRÜ
---BETWEEN SORGULAMA SÖZCÜĞÜ
---KARAKTER TÜRÜ BİLGİ İÇİNDE ARAMA YAPMA -LIKE SÖZCÜĞÜ
5.SQLDE ARİTMETİKSEL İFADELER VE FONKSİYONLAR
---SUM FONKSİYONU
---AVG FONKSİYONU
---MAX FONKSİYONU
---MIN FONKSİYONU
---COUNT FONKSİYONU
6.GRUPLANDIRARAK İŞLEM YAPMAK
---GROUP BY
---HAVING
---BİRDEN FAZLA TABLOYU İLİŞKİLENDİRMEK (JOIN)
---SELF-JOIN
---NESTED SELECTS (İÇİÇE SEÇİMLER)
---UNION SÖZCÜĞÜ
------KOŞULLAR
---------ANY / ALL / EXISTS / NOT EXISTS
---------EXCEPT / INTERSECT / SAVE TO TEMP / KEEP
7.TABLOLARDA DEĞİŞİKLİK YAPMAK
---INSERT INTO tablo VALUES değerler
---DELETE FROM tablo WHERE alan = 1
---UPDATE tablo SET alan = alan * 2
---CREATE INDEX ON tablo
------TEK BİR ALANA GÖRE ARTAN SIRADA İNDEKSLEME
------TEK BİR ALANA GÖRE AZALAN SIRADA İNDEKSLEME
------BİRDEN FAZLA ALANA GÖRE İNDEKSLEME
-----------UNİQUE SÖZCÜĞÜ
------MEVCUT BİR İNDEKSİN SİLİNMESİ
---TABLONUN YAPISINDA DEĞİŞİKLİK YAPMAK
------ALTER TABLE
-----------ADD KOMUTU (MEVCUT BİR TABLOYA ALAN (FIELD) EKLEMEK)
-----------MODIFY KOMUTU (MEVCUT BİR TABLONUN ALANLARINDA DEĞİŞİKLİK YAPMAK)
-----------DROP KOMUTU (MEVCUT BİR TABLODAN BİR ALAN SİLMEK)
-----------RENAME KOMUTU (MEVCUT BİR TABLONUN ADINI DEĞİŞTİRMEK)
-----------DROP TABLE (MEVCUT BİR TABLONUN TÜMÜYLE SİLİNMESİ)
---CREATE VIEW (VERİ GÜVENLİĞİ)
------WITH CHECK OPTION
------EKLEME
------DELETE
------UPDATE
------DROP
8.DAHA FAZLA ÖRNEK VE AÇIKLAMA
1.TEK TABLODAN SORGULAMALAR:
SELECT * FROM tablo
ÖRNEK: Bütün bilgileri personel tablosundan koşulsuz olarak listele.
SELECT * FROM personel
ÖRNEK: Personel tablosundan SEÇ komutuyla istenen sütun adlarını belirt.
SELECT sicil,sosy_g_no,ad,soyad,dog_tar,
sicil,sosy_g_no,ad,soyad,dog_tar,
adres,cins,brüt,böl_no,yön_s_g_n
FROM personel;
ÖRNEK: Personel tablosundan istenen sütün başliklarini listele.
SELECT sicil,ad,soyad,brüt
FROM personel;
DISTINCT (Tekrarsız)
TANIM: SQLde tablo içinde birbirinin aynı datalar bulunabilir.Aynı satırların listeleme esnasında bir kez yazılması için Distinct sözcüğünü kullan.
ÖRNEK: Par _sat dosyasından sat_nolar tekrarsız olarak listelenecektir.
SELECT DISTINCT sat_no
FROM par_sat;
2.TABLO BİLGİLERİNİN SIRALANMIŞ OLARAK LİSTELENMESİ:
ORDER BY (Sırasıyla)
TANIM:Tablodaki sütunlardan ,belirli bir sütuna göre listelemek için SELECT komutuna , ORDER BY eklenir.
ÖRNEK: Personel dosyasından,sicil,ad,soyad,brüt sütunlarını seç ve brüt(maaşa)göre büyükten küçüğe sırala.
SELECT sicil,ad,soyad,brüt
FROM personel
ORDER BY brüt ASC;
DESC : Küçükten büyüğe sırala (A-Z) ASC : Büyükten küçüğe sırala (Z-A)
DESC yazılmazsa ASC direct kabul edilir (DEFAULT)
3.BİRDEN ÇOK ALANA GÖRE SIRALAMA:
TANIM: Bir tablo içinde ,birden fazla sütundan aynı anda sıralamak için kullanılır.
ÖRNEK )Personel dosyasından seçilen sütunlarını aynı anda hem ad,hem de otomatik olarak sıralar.
SELECT sicil,ad,soyad,brüt
FROM personel
ORDER BY ad,brüt;
ÖRNEK Personel tablosundan seçili sütunları öncelik adda olmak üzere (Z-A) adı bozmadan soyadı (A-Z) sıralı listeler.
SELECT sicil,ad,soyad,brüt
FROM personel
ORDER BY ad ASC,soyad DESC,
brüt ASC;
veya;
SELECT sicil,ad,soyad,brüt
FROM personel
ORDER BY ad,soyad DESC,brüt;
KOŞULA BAGLI OLARAK LISTELEME:
WHERE
TANIM:Verilen koşulu saglayanlar listelenir.Iki veri birbiriyle karşilaştirilmaktadir. Karşilaştirilan verilerin türü ayni olmalidir.
SELECT *
FROM personel
WHERE brüt > 5000000;
KARŞILAŞTIRMA OPERATÖRLERI:
OPERATÖR ANLAMI :
< ...den daha küçük
> ...den daha büyük
= Eşit
<= Küçük veya eşit
>= Büyük veya eşit
<> Eşit degil
!= Eşit degil
!< ...den küçük değil
!> ...den büyük değil
ÇEŞITLI VERI TIPLERI IÇIN BASIT SORGULAMALAR:
1.NÜMERİK VERİ TİPLERİ:
ÖRNEK: Maaşi 8000000TLden fazla olmayan personeli listele.
SELECT *
FROM personel
WHERE brüt <= 8000000;
2.KARAKTER VERİ TİPLERİ (CHAR):
Karakter çift veya tek tırnak ile gösterilir.
ÖRNEK: Adı Ali olmayan personele ait kayıtları listele.
SELECT *
FROM personel
WHERE ad <> Ali;
3.TARİH VERİ TİPİ:
Tarih veri tipleri { } sembolleri içinde yazılır.
ÖRNEK: Hangi personelin doğum tarihi 1960 yılından daha öncedir?
SELECT *
FROM personel
WHERE dog_tar <={12/31/59};
4.MANTIKSAL (LOJİK) VERİ TİPİ:
Mantıksal veriler için mümkün olabilen sadece iki değer sözkonusudur.DOĞRU D(TRUE T) , YANLIŞ Y (FALSE F) ile simgelenir.
ÖRNEK: Personel tablosunda personelin cinsiyetini belirten cins adlı alan mantıksal(logical) olarak tanımlanmıştır.Cinsiyeti erkek olanları D,kadın olanları y ile tanımlarsak erkek olanları listele.
SELECT *
FROM personel
WHERE cins = .T.;
4.BİRDEN ÇOK KOŞULA DAYALI SORGULAMALAR: (NOT,AND,OR)
TANIM:Mantıksal operatörlerin yardımı ile birden çok koşulun gerçekleştirmesine bağlı olarak ifade edilebilecek (karmaşık yada birleşik koşullu listelemeleri gerçekleştirilmektedir.)
AND (VE)
ÖRNEK: Maaşı 5000000dan fazla olan ve cinsiyeti erkek olan personelin listelenmesi istenir yani iki koşul verilmektedir ve ikisininde olmasi istenir.
SELECT *
FROM personel
WHERE brüt >5000000 AND cins =.T.;
NOT (DEĞİL)
OR (VEYA)
ÖRNEKLER:
1.Doğum tarihi 1960dan önce olan maaşı 6000000 - 10000000 arasındaki bayan personelin listele.
SELECT *
FROM dog_tar < {01/01/60} AND
brüt > = 6000000 AND brüt < =10000000
AND cins = .F.;
2.Satış bölümüyle muhasebe bölümündekiler kimlerdir?
(Satış bölümünün böl_nosunun 1 ve muhasebe bölümünün böl_nosunun 2 olduğu varsayılmaktadır.)
SELECT *
FROM personel
WHERE bol_no =1 OR bol_no = 2;
3.Bölümü Satış yada Muhasebe olamayan 1960dan sonra doğmuş bayan personeli listele.
1.YAZILIM:
SELECT *
FROM personel
WHERE NOT (böl_no =1 OR
böl_no =2) AND dog_tar > ={01/01/60}
AND cins =.F.;
2.YAZILIM:
SELECT *
FROM personel
WHERE böl_no <> 1 AND
böl_no <> 2 AND dog_tar > ={01/01/60}
AND cins =.F.;
BİR VERİ KÜMESİNDE ARAMA -IN OPERATÖRÜ
IN (İÇİNDE)
IN operatörü NOT ile kullanılılabilir.
ÖRNEK: Bölümü 1,2,3 olmayan personel kimlerden oluşmaktadir?
SELECT *
FROM personel
WHERE bol_no NOT IN (1,2,3);
ÖRNEK: Böl_nosu 1,2 yada 3 olan personeli listele.
SELECT *
FROM personel
WHERE böl_no = 1 OR böl_no= 2 OR
böl_no = 3;
Bu örneğin IN ile yapılmış şekli daha kısadır.
SELECT *
FROM personel
WHERE NOT böl_no IN (1,2,3);
BETWEEN SORGULAMA SÖZCÜĞÜ:
BETWEEN (ARASINDA)
ÖRNEK: Maaşi 5- 10 milyon arasinda olan personel kimlerdir?
SELECT *
FROM personel
WHERE brüt > =5000000 AND
brüt < = 10000000;
BETWEEN (ARASINDA) komutu ile daha kısa olacaktır.
SELECT *
FROM personel
WHERE brüt BETWEEN 5000000
AND 10000000;
KARAKTER TÜRÜ BİLGİ İÇİNDE ARAMA
LIKE SÖZCÜĞÜ:
TANIM ÖRNEĞİ: Adres sutunu içerisinde semt bölümüne ait ayrıca bir sutun olmadığını varsayarak semt adı adres sutunu içerisinde yer alır ve buradan da LIKE (BULUNAN) komutuyla adres sutunu içerisinde Taksim semtinde oturan personeli listele.
SELECT *
FROM personel
WHERE adres LIKE % TAKSİM % ;
Adres LIKE %TAKSİM% ifadesi adres içinde her hangi bir yerde TAKSİM yazan yerde oturan personeli listeleyecektir.
LIKE sözcüğünü ,alt çizgi (-) sembolü ile birlikte kullanmakta mümkündür.
SELECT *
FROM personel
WHERE ad LIKE Mehmet -----;
Şekildeki komut ile ad alani Mehmet ile başlayan ve ad alani uzunlugu 10 karakter olan isimlere sahip personeli listeleyecektir.Mehmet Ali,Mehmet Can- Mehmetcik gibi isimler
listeleyecektir.Anlaşilacagi gibi - sembolü , tek karakterlik bir bilgiyi temsil etmektedir.
5.SQLDE ARİTMETİKSEL İFADELER VE FONKSİYONLAR :
KÜME FONKSİYONLARI:
SUM FONKSİYONU:
SUM (TOPLA)
Fonksiyonun argümanı olarak belirtilen sütun ile ilişkili olana toplama işlemini gerçekleştirir.
ÖRNEK: İşletmedeki personelin brüt maaşlar toplamı ne kadardır?
SELECT SUM (brüt)
FROM personel;
AVG FONKSİYONU:
AVG (ORTALA)
Aritmetiksel ortalama (average) hesaplamak için kullanılır.
SELECT AVG(brüt)
FROM personel;
MAX FONKSİYONU:
MAX (EN ÜST)
Tablo içinde ,belirtilen sutun (alan)içindeki en büyük değeri bulur.
ÖRNEK: İşletme içindeki en yüksek maaş ne kadardır?
SELECT MAX (brüt)
FROM personel;
MIN FONKSİYONU:
MIN (EN ALT)
Tablo içinde,belirlenen sutun alan içindeki en küçük değeri bulur.
ÖRNEK: İşletme içinde 4 Mayıs 1970den önce doğanlar için,asgari ücret nedir?
SELECT MIN(brüt)
FROM personel
WHERE dog_tar < {05/04/70};
COUNT FONKSİYONU:
COUNT (SAY)
Tablo içinde, her hangi bir sayma işlemi gerçekleştirmek için kullanilir.
ÖRNEK:Ücreti 6000000dan olan personel sayısı nedir?
SELECT COUNT (*)
FROM personel
WHERE brüt > 6000000;
COUNT (SAY) fonksiyonu DISTINCT (TEKRARSIZ)sözcüğü ile de kullanılır.
ÖRNEK: Personel tablosunda mevcut personelin işletme içinde kaç tane farkli bölümde çaliştigini bul.
SELECT COUNT(DISTINCT böl_no)
FROM personel;
COUNT (böl_no)
6.GRUPLANDIRARAK İŞLEM YAPMA:
GROUP BY (GRUPLA)
ÖRNEK: Her bölümdeki ortalama maaş nedir?
SELECT böl_no,AVG (brüt)
FROM personel
GOUP BY böl_no;
HAVING:
HAVING (SAHİP)
Gruplandırarak kümeleme fonksiyonunu uygularken koşulda verilebilir.Bu durumda grup üzerindeki hesaplamalarla ilgili koşul belirtilirken HAVING (SAHİP) sözcüğü kullanılır.
ÖRNEK: En yüksek maaşin 9000000dan fazla oldugu bölümlerdeki personele ait ortalama maaşlari listele.
SELECT böl_no,AVG (brüt)
FROM personel
GROUP BY böl_no
HAVING AVG(brüt)> 9000000;
HAVING sözcüğü SELECT konusunda GROUP BY bulunmadığı zaman geçersizdir. HAVING sözcüğünü izleyen ifade içinde SUM , COUNT(*) ,AVG, MAX yada MIN fonksiyonlarından en az biri bulunmalıdır.
HAVING sözcüğü sadece gruplanmış veriler üzerindeki işlemlerde geçerlidir.
WHERE sözcüğü bir tablonun tek tek satırları üzerinde işlem yapan koşullar içinde geçerlidir.
Bazı durumlarda HAVING ve WHERE sözcükleri ile birlikte SELECT komutu içinde kullanılabilir.
ÖRNEK: Personel tablosu içinde her bölümde erkek personele ait maaşlar için ortalamanin 9000000dan fazla oldugu bölümleri listele.
SELECT böl_no, AVG (brüt)
FROM personel
WHERE cins= .T.
GROUP BY böl_no
HAVING AVG (brüt) > 9000000;
BİRDEN FAZLA TABLOYU İLİŞKİLENDİRMEK:
JOIN (İLİŞKİLENDİR)
ÖRNEK: Personel ve bölüm adlı 2 tablo bulunmaktadır.
Çalışan her personel ve personelin yöneticisi ile ilişkili bilgiler nelerdir?
SELECT *
FROM personel,bölüm
WHERE personel .böl_no=bölüm.bölüm_no ;
ÖRNEK: JOIN (İLİŞKİLENDİR) işleminde arzu edilen(sicil,ad,soyad,böl_no,yön_s_g_n) alanların listele.
SELECT sicil,ad,soyad,böl_no,yön_s_g_n
FROM personel,bölüm
WHERE personel .böl_no = bölüm .bölüm_no;
SELF-JOIN: KENDİSİYLE -İLİŞKİLENDİR:
TANIM:Bir tablonun kendisi ile birleştirilmesine KENDISIYLE-ILIŞKiLENDIR denir.(SELF-JOIN)
SELECT A. sicil , A.ad , A.soyad,
B .ad , B.soyad , B.dog_tar
FROM personel A , personel B
WHERE A. yon_sos_g_n =B .sosy_g_no;
NESTED SELECTS:
İÇİÇE SEÇİMLER
TANIM: İç içe geçmiş SELECT komutlarından oluşur. İçteki Select komutunun bulduğu sonucu dış takı komutumuz işlevini yerine getirmesi için kullanılır.
ÖRNEKarça numarası 24 olan parçayı ,projelerde kullanan çalışan personeli listele.
SELECT *
FROM personel
WHERE sosy_g_no
IN(SELECT per_s_g_no
FROM parça,proje,çalışma
WHERE pr_no = proj_no AND
proj_no =proj_no AND
par_no =24);
ÖRNEK: Fatihte oturan personelin çalıştığı projelerin adlarını ve yerlerini listele.
SELECT proj_ad,yer
FROM proje
WHERE proj_no IN
(SELECT proje_no
FROM personel,çalışma
WHERE sosy_g_no = per_s_g_no
AND adres LIKE % fatih %);
UNION SÖZCÜĞÜ:
UNION (BİRLEŞİM)
TANIM: İki ayrı SEÇ komutunun sonucunda elde edilen tabloların birleşimi işlemini gerçekleştirir.
ÖRNEK: Adı Ahmet ve Soyadı Caner olan kişi yada kişileri işletmenin yürüttüğü projelerde çalışan bir kişi (sıradan bir personel yada bölüm yöneticisi)olarak bulunduran projelerin isimlerini ve projelerin yürütüldüğü yerleri listele.
(SELECT proj_ad,yer
FROM proj,bölüm,personel
WHERE bl_no=bölüm_no AND
y_sos gno = sosy_g_no
AND ad =AhmetAND soyad =Caner)
UNION (SELECT proj_ad,yer
FROM proje,çalışma,personel
WHERE proj_no = proje_no AND
Per_s_g_no = sosy_g_no AND ad =Ahmet
AND soyad =Caner)
KOŞULLAR:
UNION (BİRLEŞİM) sözcüğü ile ,iki yada daha çok kişi SELECT in sonucu olan tabloların küme birleşimi işlemine tabi tutulması için 2 koşul gereklidir.
1) SELECT komutları sonucunda elde edilecek tablolar aynı sayıda kolon içermelidirler.
2)Sonuç tabloları karşılıklı olarak kolonların aynı veri tipi ve aynı genişlikte olmalıdır.
ANY :
ANY (HER HANGİ BİRİ)
ÖRNEK:Satış bölümünde çalışan personelin her hangi birinden daha düşük maaş alan ve mühendislik bölümündeki kişileri listele.
SELECT *
FROM personel
WHERE brüt < ANY
(SELECT brüt
FROM personel
WHERE böl_no = 2) AND
böl_no =1;
Aynı ifade aşağıdaki gibi yazılabilir:
SELECT *
FROM personel
WHERE brüt < (SELECT MAX (brüt )
FROM personel
WHERE böl_no = 2) AND böl_no =1;
ALL (HEPSİ)
ÖRNEK: Satış bölümünde çalışan ve mühendislik bölümündeki personelin hepsinden daha fazla maaş alan personeli listele.Bu örnekte satış bölümü kodu = 2 ve mühendislik bölümü kodu = 1 alınmıştır.
YAPILIŞ YOLU:
1) SELECT *
FROM personel
WHERE brüt >
ALL (SELECT brüt
FROM personel
WHERE böl_no = 1)
AND böl_no = 2;
2) SELECT *
FROM personel
WHERE brüt >
(SELECT MAX (brüt)
FROM personel
WHERE böl_no = 1)
AND böl_no =2;
EXISTS (MEVCUT)
VE ,VEYA ,DEĞİL operatörleri ile kullanılabilir.
ÖRNEK: 27 nolu parçayı satan satıcılarla ilişkili tüm bilgileri listele.
SELECT *
FROM satıcı
WHERE EXISTS
(SELECT *
FROM par_sat
WHERE sat_no = satıcı_n
AND parça_n =27);
NOT EXISTS (MEVCUT DEĞİL)
VE ,VEYA ,DEĞİL operatörleri ile kullanılabilir.
ÖRNEK: 27 nolu parçayı satmayan satıcılar kimlerdir?
SELECT *
FROM satıcı
WHERE NOT EXISTS
(SELECT *
FROM par_sat
WHERE sat_no = satıcı_n
AND parça_n =27);
EXCEPT (FARKLI)
Tablo-1 - Tablo-2 işlemi sonuç(iki kümenin farki) elde edilecek tabloda,Tablo-1de bulunup, Tablo-2de bulunmayan veriler mevcut olacaktir.
ÖRNEK:Satış bölümündeki personel adlarından,mühendislik bölümünde bulunmayanları listele.
SELECT * FROM
(SELECT ad FROM personel
WHERE bol_no=1
EXCEPT
SELECT ad FROM personel
WHERE bol_no =2);
INTERSECT (KESİŞİM)
ÖRNEK: Hem Ankarada,hem de İstanbuldaki projelerde görev alan bölümleri listele.
SELECT * FROM
(SELECT bl_no FROM proje
WHERE yer LIKE %Ankara%
INTERSECT
SELECT bl_no FROM proje
WHERE yer LIKE %İstanbul%);
SAVE TO TEMP (SAKLA)
ÖRNEK: Bayan personeli,bayan adlı bir tablo içinde sakla.
SELECT *
FROM personel
WHERE cins =.F. SAVE TO TEMP bayan;
KEEP:
KEEP (KALICI)
ÖRNEK:
SELECT *
FROM personel
WHERE cins = .F.
SAVE TO TEMP bayan KEEP;
7.TABLOLARDA DEĞİŞİKLİK YAPMAK:
INSERT (EKLE)
INTO (İÇİNE)
VALUES (DEĞERLER)
ÖRNEK: Bir personel tablosuna sicil_nosu 275 olan personel ile ilişkili bilgileri ekle.
INSERT INTO personel(sicil,
sosy_g_no,ad,soyad,doğ_tar
adres,cins,brüt,böl_no,yön_s_g_no
VALUES(275,27652418,Ali,Caner,
{10/05/1962},Merkez caddesi 46 -Fatih-İstanbul,
.T.,27000000,2,876215342);
DELETE (SİL)
ÖRNEK: 2 nolu bölümdeki personelin tümü tablodan sil.
DELETE FROM personel
WHERE böl_no = 2;
5 ROWS DELETED 5 SATIR SİLİNDİ
ÖRNEK:Brüt maaş alani boş olmayan tüm personeli sil.
DELETE FROM personel
WHERE brüt IS NOT NULL;
25 ROWS DELETED 25 SATIR SİLİNDİ
UPDATE (GÜNCELLE)
SET (YAP)
ÖRNEK:2inci bölümün yürüttüğü projelerde kullanılan tüm parçaların fiyatlarını % 7
zam yap.
UPDATE parça
SET fiyat = fiyat *1,07
WHERE pr_no IN
(SELECT proj_no
FROM proje
WHERE bl_no = 2;
CREATE INDEX (INDEKS YARAT )
ON (Hangi Tablo İçin)
CREATE INDEX ındeks adı
ON tablo adı(kolon adı 1,kolon adı 2,.,.kolon adı n);
TEK BİR ALANA GÖRE ARTAN SIRADA İNDEKSLEME :
ÖRNEK:İşletmede çalışan personeli brüt maaşlarına göre artan sırada listele.(Brüt alana göre bir indeks oluşturmalıyız)
CREATE INDEX pers_maas
ON personel(brüt);
INDEX CREATED 127 ROWS İNDEKS YARATILDI 127 SATIR
127 satırlık personel tablosu ile ilişkili olarak brüt kolonu indeks anahtarı olarak kullanan pers_maas adlı indeks oluşturulmuştur.Bu durumda;
SELECT *
FROM personel;
_Şeklinde listeleme komutu sonucunda personel tablosundaki tüm personel, brüt maaşlarina göre sirali olarak listelenecektir.
TEK BİR ALANA GÖRE AZALAN SIRADA İNDEKSLEME :
DESC Küçükten büyüğe (K-B)
ÖRNEK:İşletmede çalışan personeli brüt maaşlarına göre azalan sırada (yüksek maaştan düşük maaşa doğru)listelemek istersek ,brüt alanına göre aşağıdaki şekilde oluşturmak gerekir.
CREATE INDEX
ON personel (brüt DESC);
BİRDEN FAZLA ALANA GÖRE İNDEKSLEME :
ÖRNEK:İşletmedeki personelin öncelikle adlarına göre,aynı adda olanların soyadlarına göre ,hem adı hemde soyadı aynı olanların maaşlarına göre sıralanmış olarak listele.
CREATE INDEX p_ad_soy_m
ON personel (ad,soyad,brüt);
Bu durumda;
SELECT *
FROM personel;
UNIQUE (TEK)
Bir tablo,seçilen bir sutüna (alana) göre indekslenirken , indeksleme alanı olarak seçilen sutündaki verilerintekrarlanmasına müsaade edilmesi istenmiyorsa,indeksleme yapılırken ,CREATE ,INDEX komutu iinde UNİQUE sözcüğü kullanılmalıdır.
CREATE UNIQUE INDEX pers_sicil
ON personel (sicil);
EKLEME İÇİN:
Personel tablosuna
INSERT INTO Personel
VALUES(53768 ,27241685,ayşe,
şen{01/04/63},Merkez cad. 82 -
Kadıköy.F. ,27000000 ,2, 34261578);
MEVCUT BİR İNDEKSİN SİLİNMESİ:
DROP IPTAL
DROP INDEX pers_in;
Komutu ile
INDEX DROPPED (İNDEKS SİLİNDİ)
TABLONUN YAPISINDA DEĞİŞİKLİK YAPMAK:
ALTER TABLE (TABLO DEĞİŞTİR)
MEVCUT BİR TABLOYA KOLON EKLEMEK:
ADD (EKLE)
ALTER TABLE (TABLO DEĞİŞTİR) komutu içinde ADD (EKLE) ile satır ekle.
ÖRNEKersonel tablosuna ,işe başlama tarihini belirten bir kolon ekle
ALTER TABLE personel
ADD iş_baş_tar DATE;
ADD (EKLE)iş_baş_tar DATE NOT NULL (TARIH DEGERSIZ) bu şekilde kullanilsaydi bu kolon satiri gene boş kalirdi ; fakat bu kolon ile ilişkili yeni boş degerler eklemek istendiginde buna müsaade edilmeyecekti.
MEVCUT BİR TABLONUN ALANLARINDA DEĞİŞİKLİK YAPMAK :
MODIFY KOMUTU:
MODIFY (DEĞİŞTİR)
MEVCUT BİR TABLODAN BİR KOLON SİLMEK:
DROP KOMUTU :
DROP (İPTAL)
ÖRNEKersonel tablosundan iş_baş_tar kolonunu sil.
ALTER TABLE personel
DROP iş_baş_tar ;
Birden fazla kolonda silinebilir.Birden fazla kolon silmek için virgülle ayrılarak silinir.
BİR TABLONUN ADINI DEĞİŞTİRMEK:
RENAME KOMUTU:
RENAME (TABLO YENİ AD)
ALTER TABLE personel personel Tablosunda değişiklik yap
RENAME TABLE elemanlar; elemanlar tablosunun adını değiştir
MEVCUT BİR TABLONUN BİR KOLONUNUN ADININ DEĞİŞTİRİLMESİ:
RENAME:
RENAME YENİ AD
ALTER TABLE personel
RENAME brüt br-maaş;
MEVCUT BİR TABLONUN TÜMÜYLE SİLİNMESİ
DROP TABLE (TABLO İPTAL)
ÖRNEKroje tablosunu sil.
DROP TABLE proje;
VERİ GÜVENLİĞİ:
CREATE VIEW GÖRÜŞ ALANI YARAT
ÖRNEKersonel adlı temel tablodan persview adlı bir view oluştur.
CREATE VIEW perswiew
AS SELECT sicil,sos_g_no,ad,soyad,doğ_tar,
adres,cins,böl_no,yon_s_g_no
FROM personel;
VERİ BÜTÜNLÜĞÜNÜN SAĞLANMASI:
WITH CHECK OPTİON KONTROLLÜ
CREATE VIEW UST_PER_ VIEW 'Önce bir vıew oluşturulsun
AS SELECT FROM personel
WHERE brüt >25000000
WITH CHECK OPTION;
Burada, maaşi 25000000ün üzerinde olan personelden oluşan bir UST_PER_VIEW adli view oluşturulmuştur.Bu viewa brüt maaşi 13000000 olan bir personel eklemek istedigi zaman hata mesaji verecektir.
CHECK opsiyonu kullanılmasaydı hata mesajı alınmadan bu veri VİEW içine yükleyecekti.
EKLEME
INSERT INTO UST_PER_VIEW
VALUES (27521 ,27865427,ayşe,
okan ,{01/05/1962}Cumh. Cad. 46 - Taksim,
.F.,13000000 ,1 ,27651112);
VIEW İÇİNDE SATIR SİLME:
ÖRNEK:UST_PER_VIEW içinden,maaşi 2500000den az olan kişileri sil.
DELETE FROM UST_PER_VIEW
WHERE brüt < 25000000;
VIEW SATIRLARI ÜZERİNDE GÜNCELLEME :
ÖRNEK: UST_PER_VIEW adlı viewde sicili 27251 olan kişnin maaşını 37000000 olarak değiştir.
UPDATE UST_PER_VIEW
SET brüt = 37000000
WHERE sicil = 27251;
BİR VIEWU SİLMEK:
DROP VIEW (GÖRÜŞ ALANI IPTALI)
DROP VIEW UST_PER_VIEW; GÖRÜŞ ALANI IPTALI UST_PER_VIEW;
Açıklamalı Örnekler
SQL Sorgu Açıklama
"Select * From Employees" Employees tablosundan tüm alanlari seç. En basit SQL sorgusu budur.
"Select * From Title Where [Year Published] < 1889" Title tablosundan [Year Published] alani degeri 1889'dan küçük olan tüm kayitlari seç.
Not: * isareti tüm alanlarin seçilecegini gösterir. [ ] "Köseli ayraç ise alan adi bir
kelimeden fazla ise kullanilmalidir. Yani yukaridaki alan adi sadece "Year" olsaydi köseli ayraç kullanmaya gerek kalmayacakti.
"Delete From Titles Where [Year Published] < #1/1/1889#" Titles tablosundan [Year Published] alani degeri 1/1/1889'dan küçük olanlarin tümünü sil
"Select Name, Picture From Authors Where Date_of_Birth = #2/1/1947#" Authors tablosundan Date_of_Birth = 2/1/1947 denkligi olan kayitlardan Name ve Picture
alanlarini seç
Dikkat ederseniz tüm sorgularda sabit bir SELECT ... WHERE .... yapisi var. Select seçimin nereden yapilacagini Where ise eslesme kriterlerini göstermektedir.
Bu örnekte * isareti kullanilmamis ve sadece iki alan seçilmistir: "name" ve "picture"
Tarih ifadeleri ise # isaretleri arasinda yazilmalidir.
"Select [First Name], [Last Name] From Employees" Employees tablosundan sadece First Name ve Last Name alanlarini seç
"Select Employees, Department, SupvName From Supervisors, Employees Where Employees.Department = Supervisors.Department" Bu biraz daha karisik. Burada iki tablo var: Supervisors ve Employees. Bu iki tablodan üç adet alan seçilecek: 1.Employees, 2.Department, 3.SupvName. Bu iki tabloda da Department adli birer alan var. Iste bu alanlarin denkligi ile seçim yapiliyor. Yani Employees tablosunun Department alani ile Supervisor tablosunun Department alani esit ise seçim yapiliyor.
"Select Distinct [Last Name] From Employees" Employees tablosundan Last Name degeri ayni olan kayitlardan sadece birini al. Distinct anahtari birden fazla ayni deger var ise sadece ilkini alir.
"Select [Last Name], Salary From Employees Where Salary > 2100" Salary degeri 2100'den küçük olan Employees tablosu kayitlarindan yalnizca Last Name alanlarini seç.
"Select * From Orders Where [Shipped Date] = #5/12/93#" Orders tablosundan Shipped Date degeri 5/12/93'e esit olan kayitlarin tüm alanlarini seç.
"Select [Product Name], Sum ([Units in Stock]) From Products Group By [Product Name]" Products tablosundan Product Name ve Unit in Stocks alanlarini al. Ancak burada dikkat edilmesi gereken Sum( ) fonksiyonudur. Bu fonksiyon her alan degerini birbiri üzerine toplar. Seçilen alanlarin tabloya yerlestirilmesi ise Product Name alan degerinin alfabetik sirasina göre A-Z olarak yapilir.
"Select * From Employees Order By [Last Name], Asc" Employees tablosundaki tüm alanlari Last Name alan degerine göre Z-A siralamasina göre seç Yani tablodan tüm kayitlar alinacaktir, çünkü kriter olarak kullanilan WHERE sözcügü yoktur. Ancak alinan tüm kayitlar Last Name alan degerinin Z-A alfabetik sirasina göre (ters sira) siralanir. Soyadi Zahit olan kisi soyadi Orhun olan kisiden önce gösterilir. Sorgunun sonunda kullanilan ASC anahtari seçimliktir (optional). Herhangi bir sey yazilmazsa, bu anahtar degerinin DESC (A-Z) oldugu kabul edilir.
"Select [Last Name], Salary From Employees Order By Salary, Desc, [Last Name] Veritabanindan alinan kayitlarin listelemesi islemi burada iki kritere göre yapilmakta. Önce kisilerin maaslari (Salary), sonra da soyadlari (Last Name) dikkate alinmakta. Söyle düsünün; Bir sirkette ayni maasi alan 3 kisi var. Bu kisilerin soyadlari Akin, Bahçe ve Celep olsun...Bu sorgu sonucu sirkette çalisan herkes listelenecektir. Ancak bizim bu üç kisi pespese listelenecek ve siralama Akin-Bahçe-Celep seklinde olacaktir. Asagidaki örnege bakiniz:
Last Name
Salary
Filiz
300.000.000
Kara
275.000.000
Akin
250.000.000
Bahçe
250.000.000
Celep
250.000.000
Dim dbNoro as Database
Dim recLab2 as Recordset
Set dbNoro = OpenDatabase("Noroloji.mdb", dbOpenSnapshot)
Set recLab2 =
dbNorpenRecordset("SELECT * FROM LAB2 " & "WHERE ID = " & longID & " ;") Yukaridaki örneklerde sorgulara degismezler girdik. ancak programcilikta her zaman is bu kadar kolay degildir. Sizin kullanicidan girdi almaniz ve bunu run-time program içinde sorguya katmaniz gerekir. Bu örnekte ise, dbNoro adli Database nesnesini ve recLab2 adli bir recordset nesnesini ilk önce Dim ile programa tanitiyoruz. Sonra SET komutu ile önce dbNoro database nesnesine OpenDatabase metodu ile açmak istedigimiz veritabanini açiyoruz, sonra OpenRecorset Metodu ile bu veritabani (yani dbNoro) içinde kayit arayacak SQL sorgusunu çalistiriyoruz
SQL sorgularinin " " çift tirnak içine yazildigini gördünüz. Bu degismez bir kural. Bir de her sorgunun sonuna bir " ;" eklemeyi de unutmayin. Bu sorguda görülen longID ise kullanicinin klavyeden girdigi bir degerdir. Bu deger ile veritabaninin LAB2 adli tablosunda bulunan ID adli alaninin degeri esit olursa o zaman arama olumlu sonuç verir ve recLab2 nesnesi içine bulunan degerler girilir, yada söyle diyelim bulunan kayitlarin temsilcisi recLab2 adli recordset nesnesi olur. Bu recordset nesnesini bir DBGrid nesnesine baglarsaniz, otomatik olarak bulunan tüm kayitlarin gridlerde gösterildigini görürsünüz.
Dim dbs As Database, rst As Recordset
Set dbs = OpenDatabase("Northwind.mdb")
Set rst = dbs.OpenRecordset("SELECT"
& " Sum(UnitPrice*Quantity)"
& " AS [Total UK Sales] FROM Orders" & " INNER JOIN [Order Details] ON"
& " Orders.OrderID = [Order Details].OrderID"
& " WHERE (ShipCountry = 'UK');") Dim ile Database ve Recordset nesnelerini tanimla. dbs nesnesini OpenDatabase metodu ile Northwind.mdb'ye bagla (aç). Bu açilan database'in OpenRecordset metodu ile SQL sorgu yap. Bu digerlerine göre oldukça karisik bir sorgu. Bunun içinde INNER JOIN baglantisi var. Bu baglanti iki ayri tabloyu ortak bir alan ile birbirine baglar. Burada Orders ile Order Details tablolari inner join ile baglaniyor, ve baglanti kriteri ise; her iki tabloda da bulunan OrderID adli alan. Her iki tabloda da OrderID alan degeri esit olan ve ShipCountry degeri UK olan kayitlardan Orders tablosunda bulunanlarin Unit Price ve Quantity alan degerleri çarpilarak üst üste toplaniyor ve bu toplama Total UK Sales adi veriliyor. Yani bu yeni bir sütun basligi oluyor.
Sub Ad_Ara(mode As String)
Dim hasta As String
hasta = InputBox("Aradiginiz hastanin " + mode + "i:")
If hasta = "" Then Exit Sub
Hastalar_Ac
Set recHastalar = _
dbNorpenRecordset("SELECT * FROM " _
& "HASTALAR WHERE " & mode & " = '" _
& hasta & "' ")
If recHastalar.AbsolutePosition = -1 Then
MsgBox hasta + " " + mode + "inda kayitli hasta yok!", 48
Exit Sub
End If
recHastalar.MoveLast
recHastalar.MoveFirst
End Sub Ad_Ara adli bu sub benim NoroPlus programinda veritabanindan hasta aramakta kullaniliyor. Bu sub "mode" adli bir string degisken ister. Kullanici bu sub'dan önce bir seçim yapmistir. Ayni hastayi neye göre arayacaktir. Menüden adina göre aramayi seçerse bu "mode" degiskeni "ad" olacaktir, soyadina göre aramayi tercih ederse mode degiskeni "soyad" olacaktir. Bu mode degiskeni degerleri ayni zamanda Hastalar tablosundaki alan adlariyla aynidir. Yani Hastalar tablosunda da ad, soyad vs alanlari vardir. Kullanici menüden adina göre aramayi seçince, karsisina inputbox çikacak seçimine göre bilgi girmesini isteyecektir. Herhangi bit bilgi girilmezse sub'dan çikilir. Girilen deger hasta adli local bir string degiskeni içine kaydedilir. Sonra veritabani içinden OpenRecordset metodu ile parantez içindeki sorgu çalistirilir ve sonuc rechastalar adli recordset nesnesi içinde tutulur. Eger Recordset nesnesinin AbsolutePosition degeri = -1 ise bu yapilan sorguda kriterlere uyan kayit bulunmadi demektir. O zaman msgbox bir hata mesaji ile bunu kullaniciya duyurur ve sub'dan çikar. Tersi olur da kayit bulunursa MoveLast ile bulunan kayitlarin sonuna gider ve tekrar MoveFirst ile basa gelerek kaç adet kayit bulundugunu ögreniriz. Gelelim sorguya: Hastalar tablosundan tüm bilgileri almak istiyoruz, bu yüzden "*" yildiz kullandik: "SELECT * FROM HASTALAR" devaminda ise kosul cümlesi var: "WHERE " & mode & " = ' " & hasta & " ' " Bu kosul tablodaki "mode" adli alan degeri input ile girilen deger ile ayni ise dogru sonuç verecektir ve Select ifadesi çalisacaktir. Diyelim ki soyadi Kara olan hastalari arattiniz. Bu soyada sahip 10 hasta çikmis olsun. Bu rakami da Recordset nesnesinin RecordCount özelligi ile bulursunuz. Daha sonra buldugunuz hastalar arasinda Move metodlari yardimiyla dolasabilirsiniz: MoveFirst, MoveNext, Move Previous, MoveLast. Bu is çok kolaydir. Birden fazla sayida kayida ulastiginizda görünür hale getireceginiz, aksi taktirde görünmeyen command butonlari ile ileri geri hareketleri saglayabilirsiniz.
SQL (Veritabanı Sorgulama Dili)
Açıklama ve Örnekler
INDEX
1.TEK TABLODAN SORGULAMALAR
---SELECT * FROM Tablo
---SELECT * DISTINCT FROM Tablo
2.TABLO BİLGİLERİNİN SIRALANMIŞ OLARAK LİSTELENMESİ
---ORDER BY
---ORDER BY ASC DSC
3.BİRDEN ÇOK ALANA GÖRE SIRALAMA
---SELECT alan1, alan2 FROM Tablo ORDER BY alan1
---KOŞULA BAGLI OLARAK LISTELEME
-----WHERE
---KARŞILAŞTIRMA OPERATÖRLERi
-----ÇEŞITLI VERI TIPLERI IÇIN BASIT SORGULAMALAR
---------1.NÜMERİK VERİ TİPLERİ
---------2.KARAKTER VERİ TİPLERİ (CHAR)
---------3.TARİH VERİ TİPİ (DATE)
---------4.MANTIKSAL VERİ TİPİ
4.BİRDEN ÇOK KOŞULA DAYALI SORGULAMALAR (NOT / AND / OR)
---BİR VERİ KÜMESİNDE ARAMA -IN OPERATÖRÜ
---BETWEEN SORGULAMA SÖZCÜĞÜ
---KARAKTER TÜRÜ BİLGİ İÇİNDE ARAMA YAPMA -LIKE SÖZCÜĞÜ
5.SQLDE ARİTMETİKSEL İFADELER VE FONKSİYONLAR
---SUM FONKSİYONU
---AVG FONKSİYONU
---MAX FONKSİYONU
---MIN FONKSİYONU
---COUNT FONKSİYONU
6.GRUPLANDIRARAK İŞLEM YAPMAK
---GROUP BY
---HAVING
---BİRDEN FAZLA TABLOYU İLİŞKİLENDİRMEK (JOIN)
---SELF-JOIN
---NESTED SELECTS (İÇİÇE SEÇİMLER)
---UNION SÖZCÜĞÜ
------KOŞULLAR
---------ANY / ALL / EXISTS / NOT EXISTS
---------EXCEPT / INTERSECT / SAVE TO TEMP / KEEP
7.TABLOLARDA DEĞİŞİKLİK YAPMAK
---INSERT INTO tablo VALUES değerler
---DELETE FROM tablo WHERE alan = 1
---UPDATE tablo SET alan = alan * 2
---CREATE INDEX ON tablo
------TEK BİR ALANA GÖRE ARTAN SIRADA İNDEKSLEME
------TEK BİR ALANA GÖRE AZALAN SIRADA İNDEKSLEME
------BİRDEN FAZLA ALANA GÖRE İNDEKSLEME
-----------UNİQUE SÖZCÜĞÜ
------MEVCUT BİR İNDEKSİN SİLİNMESİ
---TABLONUN YAPISINDA DEĞİŞİKLİK YAPMAK
------ALTER TABLE
-----------ADD KOMUTU (MEVCUT BİR TABLOYA ALAN (FIELD) EKLEMEK)
-----------MODIFY KOMUTU (MEVCUT BİR TABLONUN ALANLARINDA DEĞİŞİKLİK YAPMAK)
-----------DROP KOMUTU (MEVCUT BİR TABLODAN BİR ALAN SİLMEK)
-----------RENAME KOMUTU (MEVCUT BİR TABLONUN ADINI DEĞİŞTİRMEK)
-----------DROP TABLE (MEVCUT BİR TABLONUN TÜMÜYLE SİLİNMESİ)
---CREATE VIEW (VERİ GÜVENLİĞİ)
------WITH CHECK OPTION
------EKLEME
------DELETE
------UPDATE
------DROP
8.DAHA FAZLA ÖRNEK VE AÇIKLAMA
1.TEK TABLODAN SORGULAMALAR:
SELECT * FROM tablo
ÖRNEK: Bütün bilgileri personel tablosundan koşulsuz olarak listele.
SELECT * FROM personel
ÖRNEK: Personel tablosundan SEÇ komutuyla istenen sütun adlarını belirt.
SELECT sicil,sosy_g_no,ad,soyad,dog_tar,
sicil,sosy_g_no,ad,soyad,dog_tar,
adres,cins,brüt,böl_no,yön_s_g_n
FROM personel;
ÖRNEK: Personel tablosundan istenen sütün başliklarini listele.
SELECT sicil,ad,soyad,brüt
FROM personel;
DISTINCT (Tekrarsız)
TANIM: SQLde tablo içinde birbirinin aynı datalar bulunabilir.Aynı satırların listeleme esnasında bir kez yazılması için Distinct sözcüğünü kullan.
ÖRNEK: Par _sat dosyasından sat_nolar tekrarsız olarak listelenecektir.
SELECT DISTINCT sat_no
FROM par_sat;
2.TABLO BİLGİLERİNİN SIRALANMIŞ OLARAK LİSTELENMESİ:
ORDER BY (Sırasıyla)
TANIM:Tablodaki sütunlardan ,belirli bir sütuna göre listelemek için SELECT komutuna , ORDER BY eklenir.
ÖRNEK: Personel dosyasından,sicil,ad,soyad,brüt sütunlarını seç ve brüt(maaşa)göre büyükten küçüğe sırala.
SELECT sicil,ad,soyad,brüt
FROM personel
ORDER BY brüt ASC;
DESC : Küçükten büyüğe sırala (A-Z) ASC : Büyükten küçüğe sırala (Z-A)
DESC yazılmazsa ASC direct kabul edilir (DEFAULT)
3.BİRDEN ÇOK ALANA GÖRE SIRALAMA:
TANIM: Bir tablo içinde ,birden fazla sütundan aynı anda sıralamak için kullanılır.
ÖRNEK )Personel dosyasından seçilen sütunlarını aynı anda hem ad,hem de otomatik olarak sıralar.
SELECT sicil,ad,soyad,brüt
FROM personel
ORDER BY ad,brüt;
ÖRNEK Personel tablosundan seçili sütunları öncelik adda olmak üzere (Z-A) adı bozmadan soyadı (A-Z) sıralı listeler.
SELECT sicil,ad,soyad,brüt
FROM personel
ORDER BY ad ASC,soyad DESC,
brüt ASC;
veya;
SELECT sicil,ad,soyad,brüt
FROM personel
ORDER BY ad,soyad DESC,brüt;
KOŞULA BAGLI OLARAK LISTELEME:
WHERE
TANIM:Verilen koşulu saglayanlar listelenir.Iki veri birbiriyle karşilaştirilmaktadir. Karşilaştirilan verilerin türü ayni olmalidir.
SELECT *
FROM personel
WHERE brüt > 5000000;
KARŞILAŞTIRMA OPERATÖRLERI:
OPERATÖR ANLAMI :
< ...den daha küçük
> ...den daha büyük
= Eşit
<= Küçük veya eşit
>= Büyük veya eşit
<> Eşit degil
!= Eşit degil
!< ...den küçük değil
!> ...den büyük değil
ÇEŞITLI VERI TIPLERI IÇIN BASIT SORGULAMALAR:
1.NÜMERİK VERİ TİPLERİ:
ÖRNEK: Maaşi 8000000TLden fazla olmayan personeli listele.
SELECT *
FROM personel
WHERE brüt <= 8000000;
2.KARAKTER VERİ TİPLERİ (CHAR):
Karakter çift veya tek tırnak ile gösterilir.
ÖRNEK: Adı Ali olmayan personele ait kayıtları listele.
SELECT *
FROM personel
WHERE ad <> Ali;
3.TARİH VERİ TİPİ:
Tarih veri tipleri { } sembolleri içinde yazılır.
ÖRNEK: Hangi personelin doğum tarihi 1960 yılından daha öncedir?
SELECT *
FROM personel
WHERE dog_tar <={12/31/59};
4.MANTIKSAL (LOJİK) VERİ TİPİ:
Mantıksal veriler için mümkün olabilen sadece iki değer sözkonusudur.DOĞRU D(TRUE T) , YANLIŞ Y (FALSE F) ile simgelenir.
ÖRNEK: Personel tablosunda personelin cinsiyetini belirten cins adlı alan mantıksal(logical) olarak tanımlanmıştır.Cinsiyeti erkek olanları D,kadın olanları y ile tanımlarsak erkek olanları listele.
SELECT *
FROM personel
WHERE cins = .T.;
4.BİRDEN ÇOK KOŞULA DAYALI SORGULAMALAR: (NOT,AND,OR)
TANIM:Mantıksal operatörlerin yardımı ile birden çok koşulun gerçekleştirmesine bağlı olarak ifade edilebilecek (karmaşık yada birleşik koşullu listelemeleri gerçekleştirilmektedir.)
AND (VE)
ÖRNEK: Maaşı 5000000dan fazla olan ve cinsiyeti erkek olan personelin listelenmesi istenir yani iki koşul verilmektedir ve ikisininde olmasi istenir.
SELECT *
FROM personel
WHERE brüt >5000000 AND cins =.T.;
NOT (DEĞİL)
OR (VEYA)
ÖRNEKLER:
1.Doğum tarihi 1960dan önce olan maaşı 6000000 - 10000000 arasındaki bayan personelin listele.
SELECT *
FROM dog_tar < {01/01/60} AND
brüt > = 6000000 AND brüt < =10000000
AND cins = .F.;
2.Satış bölümüyle muhasebe bölümündekiler kimlerdir?
(Satış bölümünün böl_nosunun 1 ve muhasebe bölümünün böl_nosunun 2 olduğu varsayılmaktadır.)
SELECT *
FROM personel
WHERE bol_no =1 OR bol_no = 2;
3.Bölümü Satış yada Muhasebe olamayan 1960dan sonra doğmuş bayan personeli listele.
1.YAZILIM:
SELECT *
FROM personel
WHERE NOT (böl_no =1 OR
böl_no =2) AND dog_tar > ={01/01/60}
AND cins =.F.;
2.YAZILIM:
SELECT *
FROM personel
WHERE böl_no <> 1 AND
böl_no <> 2 AND dog_tar > ={01/01/60}
AND cins =.F.;
BİR VERİ KÜMESİNDE ARAMA -IN OPERATÖRÜ
IN (İÇİNDE)
IN operatörü NOT ile kullanılılabilir.
ÖRNEK: Bölümü 1,2,3 olmayan personel kimlerden oluşmaktadir?
SELECT *
FROM personel
WHERE bol_no NOT IN (1,2,3);
ÖRNEK: Böl_nosu 1,2 yada 3 olan personeli listele.
SELECT *
FROM personel
WHERE böl_no = 1 OR böl_no= 2 OR
böl_no = 3;
Bu örneğin IN ile yapılmış şekli daha kısadır.
SELECT *
FROM personel
WHERE NOT böl_no IN (1,2,3);
BETWEEN SORGULAMA SÖZCÜĞÜ:
BETWEEN (ARASINDA)
ÖRNEK: Maaşi 5- 10 milyon arasinda olan personel kimlerdir?
SELECT *
FROM personel
WHERE brüt > =5000000 AND
brüt < = 10000000;
BETWEEN (ARASINDA) komutu ile daha kısa olacaktır.
SELECT *
FROM personel
WHERE brüt BETWEEN 5000000
AND 10000000;
KARAKTER TÜRÜ BİLGİ İÇİNDE ARAMA
LIKE SÖZCÜĞÜ:
TANIM ÖRNEĞİ: Adres sutunu içerisinde semt bölümüne ait ayrıca bir sutun olmadığını varsayarak semt adı adres sutunu içerisinde yer alır ve buradan da LIKE (BULUNAN) komutuyla adres sutunu içerisinde Taksim semtinde oturan personeli listele.
SELECT *
FROM personel
WHERE adres LIKE % TAKSİM % ;
Adres LIKE %TAKSİM% ifadesi adres içinde her hangi bir yerde TAKSİM yazan yerde oturan personeli listeleyecektir.
LIKE sözcüğünü ,alt çizgi (-) sembolü ile birlikte kullanmakta mümkündür.
SELECT *
FROM personel
WHERE ad LIKE Mehmet -----;
Şekildeki komut ile ad alani Mehmet ile başlayan ve ad alani uzunlugu 10 karakter olan isimlere sahip personeli listeleyecektir.Mehmet Ali,Mehmet Can- Mehmetcik gibi isimler
listeleyecektir.Anlaşilacagi gibi - sembolü , tek karakterlik bir bilgiyi temsil etmektedir.
5.SQLDE ARİTMETİKSEL İFADELER VE FONKSİYONLAR :
KÜME FONKSİYONLARI:
SUM FONKSİYONU:
SUM (TOPLA)
Fonksiyonun argümanı olarak belirtilen sütun ile ilişkili olana toplama işlemini gerçekleştirir.
ÖRNEK: İşletmedeki personelin brüt maaşlar toplamı ne kadardır?
SELECT SUM (brüt)
FROM personel;
AVG FONKSİYONU:
AVG (ORTALA)
Aritmetiksel ortalama (average) hesaplamak için kullanılır.
SELECT AVG(brüt)
FROM personel;
MAX FONKSİYONU:
MAX (EN ÜST)
Tablo içinde ,belirtilen sutun (alan)içindeki en büyük değeri bulur.
ÖRNEK: İşletme içindeki en yüksek maaş ne kadardır?
SELECT MAX (brüt)
FROM personel;
MIN FONKSİYONU:
MIN (EN ALT)
Tablo içinde,belirlenen sutun alan içindeki en küçük değeri bulur.
ÖRNEK: İşletme içinde 4 Mayıs 1970den önce doğanlar için,asgari ücret nedir?
SELECT MIN(brüt)
FROM personel
WHERE dog_tar < {05/04/70};
COUNT FONKSİYONU:
COUNT (SAY)
Tablo içinde, her hangi bir sayma işlemi gerçekleştirmek için kullanilir.
ÖRNEK:Ücreti 6000000dan olan personel sayısı nedir?
SELECT COUNT (*)
FROM personel
WHERE brüt > 6000000;
COUNT (SAY) fonksiyonu DISTINCT (TEKRARSIZ)sözcüğü ile de kullanılır.
ÖRNEK: Personel tablosunda mevcut personelin işletme içinde kaç tane farkli bölümde çaliştigini bul.
SELECT COUNT(DISTINCT böl_no)
FROM personel;
COUNT (böl_no)
6.GRUPLANDIRARAK İŞLEM YAPMA:
GROUP BY (GRUPLA)
ÖRNEK: Her bölümdeki ortalama maaş nedir?
SELECT böl_no,AVG (brüt)
FROM personel
GOUP BY böl_no;
HAVING:
HAVING (SAHİP)
Gruplandırarak kümeleme fonksiyonunu uygularken koşulda verilebilir.Bu durumda grup üzerindeki hesaplamalarla ilgili koşul belirtilirken HAVING (SAHİP) sözcüğü kullanılır.
ÖRNEK: En yüksek maaşin 9000000dan fazla oldugu bölümlerdeki personele ait ortalama maaşlari listele.
SELECT böl_no,AVG (brüt)
FROM personel
GROUP BY böl_no
HAVING AVG(brüt)> 9000000;
HAVING sözcüğü SELECT konusunda GROUP BY bulunmadığı zaman geçersizdir. HAVING sözcüğünü izleyen ifade içinde SUM , COUNT(*) ,AVG, MAX yada MIN fonksiyonlarından en az biri bulunmalıdır.
HAVING sözcüğü sadece gruplanmış veriler üzerindeki işlemlerde geçerlidir.
WHERE sözcüğü bir tablonun tek tek satırları üzerinde işlem yapan koşullar içinde geçerlidir.
Bazı durumlarda HAVING ve WHERE sözcükleri ile birlikte SELECT komutu içinde kullanılabilir.
ÖRNEK: Personel tablosu içinde her bölümde erkek personele ait maaşlar için ortalamanin 9000000dan fazla oldugu bölümleri listele.
SELECT böl_no, AVG (brüt)
FROM personel
WHERE cins= .T.
GROUP BY böl_no
HAVING AVG (brüt) > 9000000;
BİRDEN FAZLA TABLOYU İLİŞKİLENDİRMEK:
JOIN (İLİŞKİLENDİR)
ÖRNEK: Personel ve bölüm adlı 2 tablo bulunmaktadır.
Çalışan her personel ve personelin yöneticisi ile ilişkili bilgiler nelerdir?
SELECT *
FROM personel,bölüm
WHERE personel .böl_no=bölüm.bölüm_no ;
ÖRNEK: JOIN (İLİŞKİLENDİR) işleminde arzu edilen(sicil,ad,soyad,böl_no,yön_s_g_n) alanların listele.
SELECT sicil,ad,soyad,böl_no,yön_s_g_n
FROM personel,bölüm
WHERE personel .böl_no = bölüm .bölüm_no;
SELF-JOIN: KENDİSİYLE -İLİŞKİLENDİR:
TANIM:Bir tablonun kendisi ile birleştirilmesine KENDISIYLE-ILIŞKiLENDIR denir.(SELF-JOIN)
SELECT A. sicil , A.ad , A.soyad,
B .ad , B.soyad , B.dog_tar
FROM personel A , personel B
WHERE A. yon_sos_g_n =B .sosy_g_no;
NESTED SELECTS:
İÇİÇE SEÇİMLER
TANIM: İç içe geçmiş SELECT komutlarından oluşur. İçteki Select komutunun bulduğu sonucu dış takı komutumuz işlevini yerine getirmesi için kullanılır.
ÖRNEKarça numarası 24 olan parçayı ,projelerde kullanan çalışan personeli listele.
SELECT *
FROM personel
WHERE sosy_g_no
IN(SELECT per_s_g_no
FROM parça,proje,çalışma
WHERE pr_no = proj_no AND
proj_no =proj_no AND
par_no =24);
ÖRNEK: Fatihte oturan personelin çalıştığı projelerin adlarını ve yerlerini listele.
SELECT proj_ad,yer
FROM proje
WHERE proj_no IN
(SELECT proje_no
FROM personel,çalışma
WHERE sosy_g_no = per_s_g_no
AND adres LIKE % fatih %);
UNION SÖZCÜĞÜ:
UNION (BİRLEŞİM)
TANIM: İki ayrı SEÇ komutunun sonucunda elde edilen tabloların birleşimi işlemini gerçekleştirir.
ÖRNEK: Adı Ahmet ve Soyadı Caner olan kişi yada kişileri işletmenin yürüttüğü projelerde çalışan bir kişi (sıradan bir personel yada bölüm yöneticisi)olarak bulunduran projelerin isimlerini ve projelerin yürütüldüğü yerleri listele.
(SELECT proj_ad,yer
FROM proj,bölüm,personel
WHERE bl_no=bölüm_no AND
y_sos gno = sosy_g_no
AND ad =AhmetAND soyad =Caner)
UNION (SELECT proj_ad,yer
FROM proje,çalışma,personel
WHERE proj_no = proje_no AND
Per_s_g_no = sosy_g_no AND ad =Ahmet
AND soyad =Caner)
KOŞULLAR:
UNION (BİRLEŞİM) sözcüğü ile ,iki yada daha çok kişi SELECT in sonucu olan tabloların küme birleşimi işlemine tabi tutulması için 2 koşul gereklidir.
1) SELECT komutları sonucunda elde edilecek tablolar aynı sayıda kolon içermelidirler.
2)Sonuç tabloları karşılıklı olarak kolonların aynı veri tipi ve aynı genişlikte olmalıdır.
ANY :
ANY (HER HANGİ BİRİ)
ÖRNEK:Satış bölümünde çalışan personelin her hangi birinden daha düşük maaş alan ve mühendislik bölümündeki kişileri listele.
SELECT *
FROM personel
WHERE brüt < ANY
(SELECT brüt
FROM personel
WHERE böl_no = 2) AND
böl_no =1;
Aynı ifade aşağıdaki gibi yazılabilir:
SELECT *
FROM personel
WHERE brüt < (SELECT MAX (brüt )
FROM personel
WHERE böl_no = 2) AND böl_no =1;
ALL (HEPSİ)
ÖRNEK: Satış bölümünde çalışan ve mühendislik bölümündeki personelin hepsinden daha fazla maaş alan personeli listele.Bu örnekte satış bölümü kodu = 2 ve mühendislik bölümü kodu = 1 alınmıştır.
YAPILIŞ YOLU:
1) SELECT *
FROM personel
WHERE brüt >
ALL (SELECT brüt
FROM personel
WHERE böl_no = 1)
AND böl_no = 2;
2) SELECT *
FROM personel
WHERE brüt >
(SELECT MAX (brüt)
FROM personel
WHERE böl_no = 1)
AND böl_no =2;
EXISTS (MEVCUT)
VE ,VEYA ,DEĞİL operatörleri ile kullanılabilir.
ÖRNEK: 27 nolu parçayı satan satıcılarla ilişkili tüm bilgileri listele.
SELECT *
FROM satıcı
WHERE EXISTS
(SELECT *
FROM par_sat
WHERE sat_no = satıcı_n
AND parça_n =27);
NOT EXISTS (MEVCUT DEĞİL)
VE ,VEYA ,DEĞİL operatörleri ile kullanılabilir.
ÖRNEK: 27 nolu parçayı satmayan satıcılar kimlerdir?
SELECT *
FROM satıcı
WHERE NOT EXISTS
(SELECT *
FROM par_sat
WHERE sat_no = satıcı_n
AND parça_n =27);
EXCEPT (FARKLI)
Tablo-1 - Tablo-2 işlemi sonuç(iki kümenin farki) elde edilecek tabloda,Tablo-1de bulunup, Tablo-2de bulunmayan veriler mevcut olacaktir.
ÖRNEK:Satış bölümündeki personel adlarından,mühendislik bölümünde bulunmayanları listele.
SELECT * FROM
(SELECT ad FROM personel
WHERE bol_no=1
EXCEPT
SELECT ad FROM personel
WHERE bol_no =2);
INTERSECT (KESİŞİM)
ÖRNEK: Hem Ankarada,hem de İstanbuldaki projelerde görev alan bölümleri listele.
SELECT * FROM
(SELECT bl_no FROM proje
WHERE yer LIKE %Ankara%
INTERSECT
SELECT bl_no FROM proje
WHERE yer LIKE %İstanbul%);
SAVE TO TEMP (SAKLA)
ÖRNEK: Bayan personeli,bayan adlı bir tablo içinde sakla.
SELECT *
FROM personel
WHERE cins =.F. SAVE TO TEMP bayan;
KEEP:
KEEP (KALICI)
ÖRNEK:
SELECT *
FROM personel
WHERE cins = .F.
SAVE TO TEMP bayan KEEP;
7.TABLOLARDA DEĞİŞİKLİK YAPMAK:
INSERT (EKLE)
INTO (İÇİNE)
VALUES (DEĞERLER)
ÖRNEK: Bir personel tablosuna sicil_nosu 275 olan personel ile ilişkili bilgileri ekle.
INSERT INTO personel(sicil,
sosy_g_no,ad,soyad,doğ_tar
adres,cins,brüt,böl_no,yön_s_g_no
VALUES(275,27652418,Ali,Caner,
{10/05/1962},Merkez caddesi 46 -Fatih-İstanbul,
.T.,27000000,2,876215342);
DELETE (SİL)
ÖRNEK: 2 nolu bölümdeki personelin tümü tablodan sil.
DELETE FROM personel
WHERE böl_no = 2;
5 ROWS DELETED 5 SATIR SİLİNDİ
ÖRNEK:Brüt maaş alani boş olmayan tüm personeli sil.
DELETE FROM personel
WHERE brüt IS NOT NULL;
25 ROWS DELETED 25 SATIR SİLİNDİ
UPDATE (GÜNCELLE)
SET (YAP)
ÖRNEK:2inci bölümün yürüttüğü projelerde kullanılan tüm parçaların fiyatlarını % 7
zam yap.
UPDATE parça
SET fiyat = fiyat *1,07
WHERE pr_no IN
(SELECT proj_no
FROM proje
WHERE bl_no = 2;
CREATE INDEX (INDEKS YARAT )
ON (Hangi Tablo İçin)
CREATE INDEX ındeks adı
ON tablo adı(kolon adı 1,kolon adı 2,.,.kolon adı n);
TEK BİR ALANA GÖRE ARTAN SIRADA İNDEKSLEME :
ÖRNEK:İşletmede çalışan personeli brüt maaşlarına göre artan sırada listele.(Brüt alana göre bir indeks oluşturmalıyız)
CREATE INDEX pers_maas
ON personel(brüt);
INDEX CREATED 127 ROWS İNDEKS YARATILDI 127 SATIR
127 satırlık personel tablosu ile ilişkili olarak brüt kolonu indeks anahtarı olarak kullanan pers_maas adlı indeks oluşturulmuştur.Bu durumda;
SELECT *
FROM personel;
_Şeklinde listeleme komutu sonucunda personel tablosundaki tüm personel, brüt maaşlarina göre sirali olarak listelenecektir.
TEK BİR ALANA GÖRE AZALAN SIRADA İNDEKSLEME :
DESC Küçükten büyüğe (K-B)
ÖRNEK:İşletmede çalışan personeli brüt maaşlarına göre azalan sırada (yüksek maaştan düşük maaşa doğru)listelemek istersek ,brüt alanına göre aşağıdaki şekilde oluşturmak gerekir.
CREATE INDEX
ON personel (brüt DESC);
BİRDEN FAZLA ALANA GÖRE İNDEKSLEME :
ÖRNEK:İşletmedeki personelin öncelikle adlarına göre,aynı adda olanların soyadlarına göre ,hem adı hemde soyadı aynı olanların maaşlarına göre sıralanmış olarak listele.
CREATE INDEX p_ad_soy_m
ON personel (ad,soyad,brüt);
Bu durumda;
SELECT *
FROM personel;
UNIQUE (TEK)
Bir tablo,seçilen bir sutüna (alana) göre indekslenirken , indeksleme alanı olarak seçilen sutündaki verilerintekrarlanmasına müsaade edilmesi istenmiyorsa,indeksleme yapılırken ,CREATE ,INDEX komutu iinde UNİQUE sözcüğü kullanılmalıdır.
CREATE UNIQUE INDEX pers_sicil
ON personel (sicil);
EKLEME İÇİN:
Personel tablosuna
INSERT INTO Personel
VALUES(53768 ,27241685,ayşe,
şen{01/04/63},Merkez cad. 82 -
Kadıköy.F. ,27000000 ,2, 34261578);
MEVCUT BİR İNDEKSİN SİLİNMESİ:
DROP IPTAL
DROP INDEX pers_in;
Komutu ile
INDEX DROPPED (İNDEKS SİLİNDİ)
TABLONUN YAPISINDA DEĞİŞİKLİK YAPMAK:
ALTER TABLE (TABLO DEĞİŞTİR)
MEVCUT BİR TABLOYA KOLON EKLEMEK:
ADD (EKLE)
ALTER TABLE (TABLO DEĞİŞTİR) komutu içinde ADD (EKLE) ile satır ekle.
ÖRNEKersonel tablosuna ,işe başlama tarihini belirten bir kolon ekle
ALTER TABLE personel
ADD iş_baş_tar DATE;
ADD (EKLE)iş_baş_tar DATE NOT NULL (TARIH DEGERSIZ) bu şekilde kullanilsaydi bu kolon satiri gene boş kalirdi ; fakat bu kolon ile ilişkili yeni boş degerler eklemek istendiginde buna müsaade edilmeyecekti.
MEVCUT BİR TABLONUN ALANLARINDA DEĞİŞİKLİK YAPMAK :
MODIFY KOMUTU:
MODIFY (DEĞİŞTİR)
MEVCUT BİR TABLODAN BİR KOLON SİLMEK:
DROP KOMUTU :
DROP (İPTAL)
ÖRNEKersonel tablosundan iş_baş_tar kolonunu sil.
ALTER TABLE personel
DROP iş_baş_tar ;
Birden fazla kolonda silinebilir.Birden fazla kolon silmek için virgülle ayrılarak silinir.
BİR TABLONUN ADINI DEĞİŞTİRMEK:
RENAME KOMUTU:
RENAME (TABLO YENİ AD)
ALTER TABLE personel personel Tablosunda değişiklik yap
RENAME TABLE elemanlar; elemanlar tablosunun adını değiştir
MEVCUT BİR TABLONUN BİR KOLONUNUN ADININ DEĞİŞTİRİLMESİ:
RENAME:
RENAME YENİ AD
ALTER TABLE personel
RENAME brüt br-maaş;
MEVCUT BİR TABLONUN TÜMÜYLE SİLİNMESİ
DROP TABLE (TABLO İPTAL)
ÖRNEKroje tablosunu sil.
DROP TABLE proje;
VERİ GÜVENLİĞİ:
CREATE VIEW GÖRÜŞ ALANI YARAT
ÖRNEKersonel adlı temel tablodan persview adlı bir view oluştur.
CREATE VIEW perswiew
AS SELECT sicil,sos_g_no,ad,soyad,doğ_tar,
adres,cins,böl_no,yon_s_g_no
FROM personel;
VERİ BÜTÜNLÜĞÜNÜN SAĞLANMASI:
WITH CHECK OPTİON KONTROLLÜ
CREATE VIEW UST_PER_ VIEW 'Önce bir vıew oluşturulsun
AS SELECT FROM personel
WHERE brüt >25000000
WITH CHECK OPTION;
Burada, maaşi 25000000ün üzerinde olan personelden oluşan bir UST_PER_VIEW adli view oluşturulmuştur.Bu viewa brüt maaşi 13000000 olan bir personel eklemek istedigi zaman hata mesaji verecektir.
CHECK opsiyonu kullanılmasaydı hata mesajı alınmadan bu veri VİEW içine yükleyecekti.
EKLEME
INSERT INTO UST_PER_VIEW
VALUES (27521 ,27865427,ayşe,
okan ,{01/05/1962}Cumh. Cad. 46 - Taksim,
.F.,13000000 ,1 ,27651112);
VIEW İÇİNDE SATIR SİLME:
ÖRNEK:UST_PER_VIEW içinden,maaşi 2500000den az olan kişileri sil.
DELETE FROM UST_PER_VIEW
WHERE brüt < 25000000;
VIEW SATIRLARI ÜZERİNDE GÜNCELLEME :
ÖRNEK: UST_PER_VIEW adlı viewde sicili 27251 olan kişnin maaşını 37000000 olarak değiştir.
UPDATE UST_PER_VIEW
SET brüt = 37000000
WHERE sicil = 27251;
BİR VIEWU SİLMEK:
DROP VIEW (GÖRÜŞ ALANI IPTALI)
DROP VIEW UST_PER_VIEW; GÖRÜŞ ALANI IPTALI UST_PER_VIEW;
Açıklamalı Örnekler
SQL Sorgu Açıklama
"Select * From Employees" Employees tablosundan tüm alanlari seç. En basit SQL sorgusu budur.
"Select * From Title Where [Year Published] < 1889" Title tablosundan [Year Published] alani degeri 1889'dan küçük olan tüm kayitlari seç.
Not: * isareti tüm alanlarin seçilecegini gösterir. [ ] "Köseli ayraç ise alan adi bir
kelimeden fazla ise kullanilmalidir. Yani yukaridaki alan adi sadece "Year" olsaydi köseli ayraç kullanmaya gerek kalmayacakti.
"Delete From Titles Where [Year Published] < #1/1/1889#" Titles tablosundan [Year Published] alani degeri 1/1/1889'dan küçük olanlarin tümünü sil
"Select Name, Picture From Authors Where Date_of_Birth = #2/1/1947#" Authors tablosundan Date_of_Birth = 2/1/1947 denkligi olan kayitlardan Name ve Picture
alanlarini seç
Dikkat ederseniz tüm sorgularda sabit bir SELECT ... WHERE .... yapisi var. Select seçimin nereden yapilacagini Where ise eslesme kriterlerini göstermektedir.
Bu örnekte * isareti kullanilmamis ve sadece iki alan seçilmistir: "name" ve "picture"
Tarih ifadeleri ise # isaretleri arasinda yazilmalidir.
"Select [First Name], [Last Name] From Employees" Employees tablosundan sadece First Name ve Last Name alanlarini seç
"Select Employees, Department, SupvName From Supervisors, Employees Where Employees.Department = Supervisors.Department" Bu biraz daha karisik. Burada iki tablo var: Supervisors ve Employees. Bu iki tablodan üç adet alan seçilecek: 1.Employees, 2.Department, 3.SupvName. Bu iki tabloda da Department adli birer alan var. Iste bu alanlarin denkligi ile seçim yapiliyor. Yani Employees tablosunun Department alani ile Supervisor tablosunun Department alani esit ise seçim yapiliyor.
"Select Distinct [Last Name] From Employees" Employees tablosundan Last Name degeri ayni olan kayitlardan sadece birini al. Distinct anahtari birden fazla ayni deger var ise sadece ilkini alir.
"Select [Last Name], Salary From Employees Where Salary > 2100" Salary degeri 2100'den küçük olan Employees tablosu kayitlarindan yalnizca Last Name alanlarini seç.
"Select * From Orders Where [Shipped Date] = #5/12/93#" Orders tablosundan Shipped Date degeri 5/12/93'e esit olan kayitlarin tüm alanlarini seç.
"Select [Product Name], Sum ([Units in Stock]) From Products Group By [Product Name]" Products tablosundan Product Name ve Unit in Stocks alanlarini al. Ancak burada dikkat edilmesi gereken Sum( ) fonksiyonudur. Bu fonksiyon her alan degerini birbiri üzerine toplar. Seçilen alanlarin tabloya yerlestirilmesi ise Product Name alan degerinin alfabetik sirasina göre A-Z olarak yapilir.
"Select * From Employees Order By [Last Name], Asc" Employees tablosundaki tüm alanlari Last Name alan degerine göre Z-A siralamasina göre seç Yani tablodan tüm kayitlar alinacaktir, çünkü kriter olarak kullanilan WHERE sözcügü yoktur. Ancak alinan tüm kayitlar Last Name alan degerinin Z-A alfabetik sirasina göre (ters sira) siralanir. Soyadi Zahit olan kisi soyadi Orhun olan kisiden önce gösterilir. Sorgunun sonunda kullanilan ASC anahtari seçimliktir (optional). Herhangi bir sey yazilmazsa, bu anahtar degerinin DESC (A-Z) oldugu kabul edilir.
"Select [Last Name], Salary From Employees Order By Salary, Desc, [Last Name] Veritabanindan alinan kayitlarin listelemesi islemi burada iki kritere göre yapilmakta. Önce kisilerin maaslari (Salary), sonra da soyadlari (Last Name) dikkate alinmakta. Söyle düsünün; Bir sirkette ayni maasi alan 3 kisi var. Bu kisilerin soyadlari Akin, Bahçe ve Celep olsun...Bu sorgu sonucu sirkette çalisan herkes listelenecektir. Ancak bizim bu üç kisi pespese listelenecek ve siralama Akin-Bahçe-Celep seklinde olacaktir. Asagidaki örnege bakiniz:
Last Name
Salary
Filiz
300.000.000
Kara
275.000.000
Akin
250.000.000
Bahçe
250.000.000
Celep
250.000.000
Dim dbNoro as Database
Dim recLab2 as Recordset
Set dbNoro = OpenDatabase("Noroloji.mdb", dbOpenSnapshot)
Set recLab2 =
dbNorpenRecordset("SELECT * FROM LAB2 " & "WHERE ID = " & longID & " ;") Yukaridaki örneklerde sorgulara degismezler girdik. ancak programcilikta her zaman is bu kadar kolay degildir. Sizin kullanicidan girdi almaniz ve bunu run-time program içinde sorguya katmaniz gerekir. Bu örnekte ise, dbNoro adli Database nesnesini ve recLab2 adli bir recordset nesnesini ilk önce Dim ile programa tanitiyoruz. Sonra SET komutu ile önce dbNoro database nesnesine OpenDatabase metodu ile açmak istedigimiz veritabanini açiyoruz, sonra OpenRecorset Metodu ile bu veritabani (yani dbNoro) içinde kayit arayacak SQL sorgusunu çalistiriyoruz
SQL sorgularinin " " çift tirnak içine yazildigini gördünüz. Bu degismez bir kural. Bir de her sorgunun sonuna bir " ;" eklemeyi de unutmayin. Bu sorguda görülen longID ise kullanicinin klavyeden girdigi bir degerdir. Bu deger ile veritabaninin LAB2 adli tablosunda bulunan ID adli alaninin degeri esit olursa o zaman arama olumlu sonuç verir ve recLab2 nesnesi içine bulunan degerler girilir, yada söyle diyelim bulunan kayitlarin temsilcisi recLab2 adli recordset nesnesi olur. Bu recordset nesnesini bir DBGrid nesnesine baglarsaniz, otomatik olarak bulunan tüm kayitlarin gridlerde gösterildigini görürsünüz.
Dim dbs As Database, rst As Recordset
Set dbs = OpenDatabase("Northwind.mdb")
Set rst = dbs.OpenRecordset("SELECT"
& " Sum(UnitPrice*Quantity)"
& " AS [Total UK Sales] FROM Orders" & " INNER JOIN [Order Details] ON"
& " Orders.OrderID = [Order Details].OrderID"
& " WHERE (ShipCountry = 'UK');") Dim ile Database ve Recordset nesnelerini tanimla. dbs nesnesini OpenDatabase metodu ile Northwind.mdb'ye bagla (aç). Bu açilan database'in OpenRecordset metodu ile SQL sorgu yap. Bu digerlerine göre oldukça karisik bir sorgu. Bunun içinde INNER JOIN baglantisi var. Bu baglanti iki ayri tabloyu ortak bir alan ile birbirine baglar. Burada Orders ile Order Details tablolari inner join ile baglaniyor, ve baglanti kriteri ise; her iki tabloda da bulunan OrderID adli alan. Her iki tabloda da OrderID alan degeri esit olan ve ShipCountry degeri UK olan kayitlardan Orders tablosunda bulunanlarin Unit Price ve Quantity alan degerleri çarpilarak üst üste toplaniyor ve bu toplama Total UK Sales adi veriliyor. Yani bu yeni bir sütun basligi oluyor.
Sub Ad_Ara(mode As String)
Dim hasta As String
hasta = InputBox("Aradiginiz hastanin " + mode + "i:")
If hasta = "" Then Exit Sub
Hastalar_Ac
Set recHastalar = _
dbNorpenRecordset("SELECT * FROM " _
& "HASTALAR WHERE " & mode & " = '" _
& hasta & "' ")
If recHastalar.AbsolutePosition = -1 Then
MsgBox hasta + " " + mode + "inda kayitli hasta yok!", 48
Exit Sub
End If
recHastalar.MoveLast
recHastalar.MoveFirst
End Sub Ad_Ara adli bu sub benim NoroPlus programinda veritabanindan hasta aramakta kullaniliyor. Bu sub "mode" adli bir string degisken ister. Kullanici bu sub'dan önce bir seçim yapmistir. Ayni hastayi neye göre arayacaktir. Menüden adina göre aramayi seçerse bu "mode" degiskeni "ad" olacaktir, soyadina göre aramayi tercih ederse mode degiskeni "soyad" olacaktir. Bu mode degiskeni degerleri ayni zamanda Hastalar tablosundaki alan adlariyla aynidir. Yani Hastalar tablosunda da ad, soyad vs alanlari vardir. Kullanici menüden adina göre aramayi seçince, karsisina inputbox çikacak seçimine göre bilgi girmesini isteyecektir. Herhangi bit bilgi girilmezse sub'dan çikilir. Girilen deger hasta adli local bir string degiskeni içine kaydedilir. Sonra veritabani içinden OpenRecordset metodu ile parantez içindeki sorgu çalistirilir ve sonuc rechastalar adli recordset nesnesi içinde tutulur. Eger Recordset nesnesinin AbsolutePosition degeri = -1 ise bu yapilan sorguda kriterlere uyan kayit bulunmadi demektir. O zaman msgbox bir hata mesaji ile bunu kullaniciya duyurur ve sub'dan çikar. Tersi olur da kayit bulunursa MoveLast ile bulunan kayitlarin sonuna gider ve tekrar MoveFirst ile basa gelerek kaç adet kayit bulundugunu ögreniriz. Gelelim sorguya: Hastalar tablosundan tüm bilgileri almak istiyoruz, bu yüzden "*" yildiz kullandik: "SELECT * FROM HASTALAR" devaminda ise kosul cümlesi var: "WHERE " & mode & " = ' " & hasta & " ' " Bu kosul tablodaki "mode" adli alan degeri input ile girilen deger ile ayni ise dogru sonuç verecektir ve Select ifadesi çalisacaktir. Diyelim ki soyadi Kara olan hastalari arattiniz. Bu soyada sahip 10 hasta çikmis olsun. Bu rakami da Recordset nesnesinin RecordCount özelligi ile bulursunuz. Daha sonra buldugunuz hastalar arasinda Move metodlari yardimiyla dolasabilirsiniz: MoveFirst, MoveNext, Move Previous, MoveLast. Bu is çok kolaydir. Birden fazla sayida kayida ulastiginizda görünür hale getireceginiz, aksi taktirde görünmeyen command butonlari ile ileri geri hareketleri saglayabilirsiniz.