SELECT ifadesi veritbanından verileri okumak için kullanılır. Select ifadesi tek başına kullanıldığında veritabanındaki tablo üzerinde bulunan bütün verileri seçer. Ancak binlerce hatta on binlerce kaydın olduğu bir tablodan bütün verileri çekmek veritabanını zorlayacak ve uygulamanın kitlenmesine neden olacaktır. Bunun yerine SELECT TOP ilee belirtilen kadar kayıt seçilir. Select Top ifadesi ile kayıt adedi veya yüzdesi belirtildikten sonra alan adları mutlaka yazılmalıdır. Yazılan alan adlarındaki kayıtlar ekrana gelir. * işareti konulursa bütün alanlar seçilir.
NOT: SELECT TOP ifadesi her veritabanında desteklenmez. Faklı veritabanlarında aynı işi yapan başka ifadeler kullanılır.
NOT: SELECT TOP ifadesi her veritabanında desteklenmez. Faklı veritabanlarında aynı işi yapan başka ifadeler kullanılır.
Select Top SQL SERVER ve ACCESS Veritabanlarında Kullanım BiçimiEğer sadece ilk bir kaç kaydı seçecek isek SELECT TOP ifadesinden sonra seçeceğimiz kayıt adedini belirtiriz.
SELECT TOP kayit_adedi alan_adi1,alan_adi2,... FROM tablo_adi |
Eğer bütün kayıtlar içinden yüzdesel olarak seçim yapacaksakz.
SELECT TOP yuzde_degeri PERCENT alan_adi1, alan_adi2,... FROM tablo_adi |
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Sicil No |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Bilgi İşlem Sorumlusu | 3456789 |
4 | İlhan ÖZLÜ | İstanbul | Muhasebe | 7677667 |
Örnek1:
SELECT TOP 2 Adi_soyadi, Sehir FROM Personel
Bu kod ile tablodaki Adi_soyadi ve Sehir alanlarındaki kayıtlardan sadece ilk iki tanesi seçilir.
Çıktısı:
Adi_soyadi | Sehir |
Salih ESKİOĞLU | İstanbul |
Ayhan ÇETİNKAYA | Kocaeli |
Örnek2:
SELECT TOP 25 Percent * FROM Personel
Bu örnekte Personel tabosunda bütün alanlar seçilmektedir. Ancak bütün kayıtlardan sadece yüzde 25'i seçilmiştir. Tablomuzda toplam 4 kayıt olduğu için bu kod ile sadece 1 kayıt seçilmiş olur.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Sicil No |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
Select Top MySQL ve ORACLE Veritabanlarında Kullanım Biçimi
MySQL Kullanım Biçimi: MySQL veritabanlarında ilgili seçim LIMIT ifadesi ile gerçekleştirilmektedir.
MySQL Kullanım Biçimi: MySQL veritabanlarında ilgili seçim LIMIT ifadesi ile gerçekleştirilmektedir.
SELECT alan_adi1,alan_adi2,... FROM tablo_adi LIMIT kayit_adedi |
Oracle Kullanım Biçimi: ORACLE veritabanlarında WHERE ROWNUM ifadesi ile birlikte kullanılır.
SELECT alan_adi1,alan_adi2,... FROM tablo_adi WHERE ROWNUM <= kayit_adedi |
Örnek3:
SELECT Adi_soyadi FROM Pesonel LIMIT 3
SELECT Adi_soyadi FROM Pesonel LIMIT 3
Bu örnekte sadece Adi_soyadi alanındaki ilk 3 kayıt seçilmketedir.
Çıktısı:
Adi_soyadi |
Salih ESKİOĞLU |
Ayhan ÇETİNKAYA |
Serkan ÖZGÜREL |
Örnek4:
SELECT Bolum FROM Pesonel WHERE ROWNUM <= 3
SELECT Bolum FROM Pesonel WHERE ROWNUM <= 3
Bu örnekte sadece Bolum alanındaki ilk 3 kayıt seçilmketedir.
Çıktısı:
Bolum |
Bilgi İşlem Sorumlusu |
İdari İşler Yöneticisi |
Bilgi İşlem Sorumlusu |
SQL SELECT TOP Kullanımı
DELETE ifadesi tablomuzda bulunan kayıtları silmek için kullanılır.
DELETE Kullanım Biçimi
DELETE Kullanım Biçimi
DELETE FROM tablo_adi WHERE secilen_alan_adi=alan_degeri |
Burada dikkat edilecek nokta WHERE ifadesi ile belli bir kayıt seçilip silinir. Eğer WHERE ifadesini kullanmadan yaparsak tablodaki bütün kayıtları silmiş oluruz.
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | İstanbul | Muhasebe | 3456789 |
Örnek1:
DELETE FROM Personel
WHERE id=3
Tablomuzda bulunan kayıtlarda WHERE ifadesi ile id alanında 3 yazan kaydı silmiş olduk. Metin karakterli alanlara tek tırnak işareti kullanılır. Sayısal alanlarda direk olarak yazılır. Bazı veritbanı editörleri sayısal alana veri girerken de te tırnak işareti içinde yazımı kabul etmektedir.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
Örnek2:DELETE FROM Personel
WHERE Sehir='İstanbul'
Bu kodda WHERE ifadesi ile Sehir alanında İstanbul yazan kayıtları silmiş olduk.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 1111111 |
sql birden fazla kolonu güncelleme yapmak
,
sql çoklu update
,
sql select kullanimi
,
sql silme islemi yapmak
,
sql top 5 kayıtı getirmek
,
sql where kullanımı örnekli
.
1
SQL DELETE Kullanımı
UPDATE ifadesi tablomuzda bulunan kayıtları güncellemek yani değiştirmk için kullanılır.
UPDATE Kullanım Biçimi
UPDATE Kullanım Biçimi
UPDATE tablo_adi SET alan_adi1=deger1, alan_adi2=deger2, alan_adi3=deger3, ...) WHERE secilen_alan_adi=alan_degeri |
Burada dikkat edilecek nokta WHERE ifadesi ile belli bir kayıt veya kayıtlar seçilip değiştirilmek istenilen alanlardaki değerler değiştirilir. Eğer WHERE ifadesini kullanmadan yaparsak tablodaki bütün kayıtları değiştirmiş oluruz.
Örnek Tablo Uygulaması:
Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
Örnek Tablo Uygulaması:
Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 3456789 |
Örnek1:
UPDATE Personel
SET Sehir='Ankara',Meslek_kodu=5555555
WHERE id=3
Tablomuzda bulunan kayıtlarda WHERE ifadesi ile id alanında 3 yazan kaydı seçmiş olduk. İlgili kaydın Sehir alanını Ankara ve Meslek_kodu alanını da 5555555 olarak değiştirdik. Metin karakterli alanlara tek tırnak işareti kullanılır. Sayısal alanlarda direk olarak yazılır. Bazı veritbanı editörleri sayısal alana veri girerken de te tırnak işareti içinde yazımı kabul etmektedir.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Ankara | Muhasebe | 5555555 |
Örnek2:
UPDATE Personel
SET Meslek_kodu=1111111
Bu kodda WHERE ifadesi olmadığı için mevcut olan bütün kayıtların Meslek_kodu alanını 1111111 olarak değiştirir..
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1111111 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 1111111 |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 1111111 |
SQL UPDATE Kullanımı
INSERT INTO ifadesi tablomuza yeni bir kayıt eklemek için kullanılır.
INSERT INTO Kullanım Biçimi
INSERT INTO Kullanım Biçimi
Insert Into kodu iki türlü kullanılabilir.
Birinci yöntem: Bu yöntemde direk tablo adı belirterek sadece değerleri yazmak surtiyle kayıt ekleyebiliriz. Ancak burada dikkat edeceğimiz nokta eklenecek değer tablomuzdaki alan sırasına göre olmalıdır. Mesele tablomuzdaki alan sıralaması Ad, Soyad, ve Dogum_yili seklinde olsun. Values ifadesinden yazılacak değerler sırası ile işlenir. Karışık yazdığımız zaman, Dogum_yili alanı sayısal bir alan ise metinsel veri girilemeyeceği için programımız hata verecektir. Veya sıralamya dikkat etmezsek bilgilerimiz olması gerek alana yazılmaz.
Birinci yöntem: Bu yöntemde direk tablo adı belirterek sadece değerleri yazmak surtiyle kayıt ekleyebiliriz. Ancak burada dikkat edeceğimiz nokta eklenecek değer tablomuzdaki alan sırasına göre olmalıdır. Mesele tablomuzdaki alan sıralaması Ad, Soyad, ve Dogum_yili seklinde olsun. Values ifadesinden yazılacak değerler sırası ile işlenir. Karışık yazdığımız zaman, Dogum_yili alanı sayısal bir alan ise metinsel veri girilemeyeceği için programımız hata verecektir. Veya sıralamya dikkat etmezsek bilgilerimiz olması gerek alana yazılmaz.
INSERT INTO tablo_adi VALUES (deger1, deger2, ...) |
İkinci yöntem: Bu yöntemde ise eklenecek alanları ve değerleri kendimiz belirtiriz. Burada dikkat edilmesi gereken şey; yazdığımız alan adının sırasına göre değerleri eklememiz olacaktır.
INSERT INTO tablo_adi (alan_adi1, alan_adi2, alan_adi3) VALUES (deger1, deger2, deger3) |
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
Örnek1:
INSERT INTO Personel
VALUES (3, 'Serkan ÖZGÜREL', 'Erzincan', 'Muhasebe', 3456789)
Yukarıda görüldüğü gibi tablomuza yeni bir kayıt ekleme kodunu yazdık. Alan adlarını sırası ile kontrol ettik ve değerlerimizi sıraya dikkat ederek girdik. Metin karakterli alanlara veri eklenirken tek tırnak işareti kullanılır. Sayısal alanlara veri eklerken ifade direk olarak yazılır. Bazı veritbanı editörleri sayısal alana veri girerken de te tırnak işareti içinde yazımı kabul etmektedir.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 3456789 |
Örnek2:INSERT INTO Personel (id, adi_soyadi, sehir)
VALUES (3, 'Serkan ÖZGÜREL', 'Erzincan')
Bu kod ile tablomuza sadece 3 alan için yeni kayıt eklenir .
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan |
sql birden fazla kolonu güncelleme yapmak
,
sql çoklu update
,
sql insert into kullanımı
,
sql select kullanimi
,
sql silme islemi yapmak
,
sql top 5 kayıtı getirmek
,
sql where kullanımı örnekli
.
1
SQL INSERT INTO Kullanımı
ORDER BY ifadesi kayıtları belirtilen alanda büyükten küçüğe veya küçükten büyüğe göre sıralar. ASC (ascending) parametresi ile küçükten büyüğe, DESC (descending) parametresi ile büyükten küçüğe göre sıralar. Burada sadece sayısal alanlar değil metinsel alanlarda alfabetik olarak sıralanabilir.
ORDER BY Kullanım Biçimi
ORDER BY Kullanım Biçimi
SELECT alan_adi1,alan_adi2 FROM tablo_adi ORDER BY alan_adi2 ASC SELECT alan_adi1,alan_adi2 FROM tablo_adi ORDER BY alan_adi2 DESC |
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 3456789 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
Örnek1:
SELECT * FROM Personel ORDER BY Meslek_Kosu ASC
Bu kod tablodaki Meslek_Kodu alanına göre kayıtları küçükten büyüğe doğru alır.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 3456789 |
Örnek2:SELECT * FROM Personel ORDER BY Adi_soyadi DESC
Bu kod Adi_soyadi alanına göre kayıtları büyükten küçüğe yani Z harfinden A harfine doğru dizer. .
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 3456789 |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
Örnek3:SELECT * FROM Personel Where Sehir='İstanbul' ORDER BY Meslek_kodu ASC
Bu kod Sehir alanında İstanbul yazan kayıtları seçer. ORDER BY ise sadece bu seçili olan kayıtlar üzerinde Meslek_kodu alanını baz alarak küçükten büyüğe doğru sıralama yapar.
Bu kod Sehir alanında İstanbul yazan kayıtları seçer. ORDER BY ise sadece bu seçili olan kayıtlar üzerinde Meslek_kodu alanını baz alarak küçükten büyüğe doğru sıralama yapar.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
SQL ORDER BY Kullanımı
AND ve OR ifadeleri birden fazla alanda işlem yapılacaksa kullanılan operatörlerdir. AND operatörü birinci durumla beraber ikinci durumunda olduğu zaman kullanılır. OR operatörü ise birinci durum veya ikinci durumun gerçekleşmesi durumunda kullanılır
ANd ve OR Kullanım Biçimi
ANd ve OR Kullanım Biçimi
SELECT alan_adi1,alan_adi2 FROM tablo_adi WHERE alan_adi1=sorgu_degeri AND alan_adi2=sorgu_degeri SELECT alan_adi1,alan_adi2 FROM tablo_adi WHERE alan_adi1=sorgu_degeri OR alan_adi2=sorgu_degeri |
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 3456789 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
Örnek1:
SELECT * FROM Personel WHERE Sehir='İstanbul' AND Bolum='Bilgi İşlem Sorumlusu'
Bu kod tablodaki Sehir alanında İstanbul ve Bolum alanında Bilgi İşlem Sorumlusu yazan kayıtları alır.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
Örnek2:SELECT * FROM Personel WHERE Sehir='İstanbul' AND Sehir='Kocaeli'
Bu kod Sehir alanında İstanbul ve Kocaeli yazan kayıtları alır.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
SQL AND ve OR Kullanımı
WHERE ifadesi tablodaki alanlarda okuma, güncelleme, silme gibi işlemleri yaparken belli kriterlere sahip kayıtlar üzerinde işlem yapmamızı sağlar. Where ifadesi belirtilmezse uygulanan komut bütün kayıtlar üzerinde geçerli olur. Mesela bir kaydı silmek istediğimiz zaman Where ifadesini kullanmazsak tablodaki bütün kaıtları silecektir.
Where Kullanım Biçimi
Where Kullanım Biçimi
SELECT alan_adi1,alan_adi2 FROM tablo_adi WHERE alan_adi=sorgu_degeri |
İlk bakışta kod biraz karışık görünebilir. Açıklayacak olursak;
SELECT ifadesi ile sorgunun bir seçme yani veritabanından okuma işlemi yapacağımız belirtmiş olduk. Sonrasında ise hangi alanlarda okuma yapacağımızı belirtiyoruz. Eğer silme işlemi yapacaksak select ifadesi yerine Delete ifadesi kullanılmalıdır.
FROM ifadesi ile veritabanı içindeki hangi tabloda işlem yapılacağı belirtiliyor.
WHERE ifadesi ile yapmak istediğimiz işlem (seçme, silme vs.) için gerekli parametreleri belirteceğimiz bölüm başlıyor.
Where ifadesinin hemen ardından hangi alandaki kritere göre işlem yapacaksan o alan adını yazıyoruz. sorgu_degeri ifadesi ile seçtiğimiz alandaki veri değerini giriyoruz.
Burada eşittir işareti yerine başka operatör işaretleride kullanılabilir. Mesele belli bir sayıdan büyük veya küçük olması durumlarına göre sorgulama yapılabilir. Veya iki tarih arası sorgulama yapılabilir. Aşağıdaki örneklerde detaylı olarak anlatılmıştır. Sayfanın sonunda eşittir dışındaki operatörleri ve ne işe yaradıkları tabloyu inceleyebilirsiniz.
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
SELECT ifadesi ile sorgunun bir seçme yani veritabanından okuma işlemi yapacağımız belirtmiş olduk. Sonrasında ise hangi alanlarda okuma yapacağımızı belirtiyoruz. Eğer silme işlemi yapacaksak select ifadesi yerine Delete ifadesi kullanılmalıdır.
FROM ifadesi ile veritabanı içindeki hangi tabloda işlem yapılacağı belirtiliyor.
WHERE ifadesi ile yapmak istediğimiz işlem (seçme, silme vs.) için gerekli parametreleri belirteceğimiz bölüm başlıyor.
Where ifadesinin hemen ardından hangi alandaki kritere göre işlem yapacaksan o alan adını yazıyoruz. sorgu_degeri ifadesi ile seçtiğimiz alandaki veri değerini giriyoruz.
Burada eşittir işareti yerine başka operatör işaretleride kullanılabilir. Mesele belli bir sayıdan büyük veya küçük olması durumlarına göre sorgulama yapılabilir. Veya iki tarih arası sorgulama yapılabilir. Aşağıdaki örneklerde detaylı olarak anlatılmıştır. Sayfanın sonunda eşittir dışındaki operatörleri ve ne işe yaradıkları tabloyu inceleyebilirsiniz.
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 3456789 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
Örnek1:
SELECT * FROM Personel WHERE Sehir='İstanbul'
Bu kod ile tablodaki Sehir alanında İstanbul bulunan kayıtları alır. Burada dikkat edilmesi gerek nokta Bolum alanı metinsel alan olduğu için eşittir işaretinden sonra aranmak istenen ifade tek tırnak işareti içinde yazılmıştır. Bazı veritabanı editör uygulamaları çift tırnak işareti kullanabilir.
Çıktısı:
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
Örnek2:Delete FROM Personel Where id=1
Bu örnekte Personel tabosundan silme işlemi yapılmaktadır. Normalde Select ifadesinden sonra hangi alanlarda işlem yapacağımızı belirtirdik. Ancak Delete komutu alanlarda işlem yapmaz ve direk olarak ilgili kaydı siler. Bu örnekte id alanında 1 yazan kaydın silinmesini belirttik. Genellikle kullanım kolaylığı açısından id alanları tabloda sayısal alan olarak işaretlenir. Sayısal alanlarda işlemler tırnak işareti olmadan yapılır. Aynı şekilde delete yerine select kullanarak kaydı seçtiğimizi varsaysak bile id alanı sayısal alan olduğu için tırnak işaretleri kullanılmaz.
Operatör işaretleri tablosu:
Operatör | Açıklaması | Kullanım Örneği | Örnek Açıklaması |
= | Belirtilen değeri belirtilen adanda arar | Where Bolum='Bilgisayar' | Bolum alaninda Bilgisayar yazan kayıtları seçer |
<> | Belirtilen değer dışındaki kayıtları arar | Where Bolum<>'Bilgisayar' | Bolum alaninda Bilgisayar yazmayan kayıtları seçer. |
> | Belirtilen değerden büyük kayıtları arar. | Where Maas>1000 | Maaşı 1000 TL nin üstünde olanları seçer. (1001 TL ve yukarısı) |
>= | Belirtilen değere eşit ve büyük olanları arar. | Where Maas>=1000 | Maaşı 1000 TL ve üstünde olanları seçer. (1000 TL ve üstü) |
< | Belitilen değerden küçük olanları arar | Where Maas<750 | Maaşı 750 TL nin altında olanları seçer. (749 TL ve altı) |
<= | Belirtilen değere eşit ve küçük olanları arar | Whee Maas<=750 | Maaşı 750 TL ve altında olanları seçer. (750 TL ve altı) |
Between | Belli bir aralıkta olan değerleri arar | Where Maas Between 750 and 1000 | Maaşı 750 TL ile 1000 TL arasında olanları seçer. |
Like | Birkaç karakteri bilinen kayıtları arar | Where Sehir Like 'S%' | Sehir alanında S ile başlayan kayıtları seçer. |
In | Birden fazla değerleri tek alanda arar. | Where Sehir in ('İstanbul','Ankara') | Sehir alanında İstanbul ve Ankara yazan kayıtları seçer. |
Not: Between, Like ve IN operatörlerinin kullanımını detaylı olarak konu başlıklarında incelenmiştir.
SQL WHERE Kullanımı
DISTINCT ifadesi tablodaki belirtilen alanda bulunan kayıtlardan birer örnek alır. Yani tekrar eden kayıtlardan bir tane alır ve bunun yanına da tekrar etmeyen kayıtları koyarak bir veri kümesi oluşturur. Ne işimize yarar veya nerede kullanabiliriz sorusu akla gelebilir.
Mesela bir üyelerinizin depolandığı bir tablo olduğunu düşünün. Bu tablodan mesela İstanbul'da kaç tane üyeniz olduğunu bulmak istediğinizi düşünün. Yaptığınız programa bir açılır liste kutusu koyup illerin isimlerini tek tek yazabilirsiniz. Ancak bu durum hem bir zaman kaybı olur hemde sistemde kayıtlı olmayan ileri de listeleyeceği için, açılır liste kutusu açıldığında uzun bir liste olacaktır. Bunun yerine Distinct komutu kullanarak tablodaki Şehir alanında yazan kayıtlar tek düşürülür ve bir açılır liste kutusuna aktarılabilir. Böylece ilgili şehir seçilerek o şehirde kaç tane üyenizin olduğunu görebilirsiniz. Listede görünmeyen şehirden üyeniz olmadığı anlamını rahatlıkla çıkarabilirsiniz.
Mesela bir üyelerinizin depolandığı bir tablo olduğunu düşünün. Bu tablodan mesela İstanbul'da kaç tane üyeniz olduğunu bulmak istediğinizi düşünün. Yaptığınız programa bir açılır liste kutusu koyup illerin isimlerini tek tek yazabilirsiniz. Ancak bu durum hem bir zaman kaybı olur hemde sistemde kayıtlı olmayan ileri de listeleyeceği için, açılır liste kutusu açıldığında uzun bir liste olacaktır. Bunun yerine Distinct komutu kullanarak tablodaki Şehir alanında yazan kayıtlar tek düşürülür ve bir açılır liste kutusuna aktarılabilir. Böylece ilgili şehir seçilerek o şehirde kaç tane üyenizin olduğunu görebilirsiniz. Listede görünmeyen şehirden üyeniz olmadığı anlamını rahatlıkla çıkarabilirsiniz.
Distinct Kullanım Biçimi
SELECT DISTINCT alan_adi1,alan_adi2 FROM tablo_adi |
Distinct kelimesinden sonra yazılacak olan alanlara otomatik olarak uygulanır. Yani birden fazla alan üzerinde Distinct yapılacaksa alanların başına tek tek yazılmaz. Ayrıca Distinct komutu tek başına kullanılamaz. Mutlaka SELECT ifadesi ile kullanılmalıdır.
Burada dikkat edilmesi gereken nokta çoklu distinct kullanımında belirtilen alanlardaki verileri bir bütün olarak ele alır ve diğer kayırlarda benzersiz alanları bulmaya çalışır. (örnek2 ve örnek3'e bakabilirisiniz.)
Burada dikkat edilmesi gereken nokta çoklu distinct kullanımında belirtilen alanlardaki verileri bir bütün olarak ele alır ve diğer kayırlarda benzersiz alanları bulmaya çalışır. (örnek2 ve örnek3'e bakabilirisiniz.)
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Meslek_Kodu |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Muhasebe | 3456789 |
4 | İlhan ÖZLÜ | İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
Örnek1:
SELECT DISTINCT Sehir FROM Personel
Bu kod ile tablodaki Sehir alanında bulunan kayıtları birer defa alır.
Çıktısı:
Sehir |
İstanbul |
Kocaeli |
Erzincan |
Örnek2:SELECT DISTNICT Sehir, Bolum FROM Personel
Bu örnekte Personel tabosundan adı soyadı ve bölüm bilgisinin tutulduğu alanlar seçilmektedir. Ancak burada dikkat edilmesi gerekn nokta iki alanın sanki tek bir alanmş gibi değelendirilmesidir.
Çıktısı:
Sehir | Bolum |
İstanbul | Bilgi İşlem Sorumlusu |
Kocaeli | İdari İşler Yöneticisi |
Erzincan | Muhasebe |
Burada dikkat edeceğiniz üzere tablomuzdaki son satırı almadı. Çünkü Sehir ve Bolum alanlarını tek bir alanmış gibi düşündüğümüz zaman "İstanbul Bilgi İşlem Sorumlusu" ifadesi ortaya çıkar. Son satırdaki kayıtta aynı ifadeye denk gelmektedir. Bu sebeple dikkate alınmadı.
Örnek3:SELECT DISTNICT Sehir, Bolum, Meslek_Kodu FROM Personel
Bu örnekte Personel tabosundan adı soyadı ve bölüm bilgisinin tutulduğu alanlar seçilmektedir. Ancak burada dikkat edilmesi gerekn nokta iki alanın sanki tek bir alanmş gibi değelendirilmesidir.
Bu örnekte Personel tabosundan adı soyadı ve bölüm bilgisinin tutulduğu alanlar seçilmektedir. Ancak burada dikkat edilmesi gerekn nokta iki alanın sanki tek bir alanmş gibi değelendirilmesidir.
Çıktısı:
Sehir | Bolum | Meslek_Kodu |
İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
Kocaeli | İdari İşler Yöneticisi | 2345678 |
Erzincan | Muhasebe | 3456789 |
İstanbul | Bİlgi İşlem Sorumlusu | 2345678 |
Bu örnekte ise bütün kayıtlar gelmiş oldu. Çünkü Sehir, Bolum ve Meslek_kodu alanlarını tek bir alanmış gibi düşündüğümüz zaman; ilk satırı örnek verecek olursak "İstanbul Bilgi İşlem Sorumlusu 1234567" ifadesi ortaya çıkar. Sehir alanında iki tane İstanbul olmasına rağmen ikiside listelenmiştir. Çünkü iki kaydın Meslek_Kodu alanında yazan değer farklıdır.
Aynı tabloyu aşağıdaki kod ile çalıştırdığımız zaman:
Select Distinct Bolum, Meslek_kodu FROM Personel
Select Distinct Bolum, Meslek_kodu FROM Personel
Çıktısı:
Bolum | Meslek_Kodu |
Bilgi İşlem Sorumlusu | 1234567 |
İdari İşler Yöneticisi | 2345678 |
Muhasebe | 3456789 |
Bilgi İşlem Sorumlusu | 2345678 |
Dikkat edileceği üzere Bilgi İşlem Sorumlusu alanı iki defa gelmiş oldu. Aynı mantıktan yola çıakrak alanların birleştirilmiş olduğunu düşünürsek, Bilgi İşlem Sorumlusu kayıtlarında Meslek_Kodu alanında 1234567 ve 2345678 verileri vardır. Dolayısı ile bu iki satır benzersiz değildir.
SQL DISTINCT Kullanımı(Tekrarlayan kayıtlar, Mükerrer kayıtlar)
SELECT ifadesi veritbanından verileri okumak için kullanılır. Veritbanındaki tablo üzerindeki bütün alanlardan veri çekilebileceği gibi belirteceğimiz bir kaç alandan da veri çekebiliriz. En azındna bir alan belirtmek gerekmektedir.
Select Kullanım BiçimiEğer bütün alanlardan veri çekeceksek, Select ifadesinden sonra * işareti konulur. Böylece bütün alanlardan veri çekileceği belirtilmiş olunur.
SELECT * FROM tablo_adi |
Eğer birkaç tane alanlardan veri çekeceksek, Select ifadesinden sonra alanarı virgüller ayırarak yazarız.
SELECT alan_adi1, alan_adi2 FROM tablo_adi |
Örnek Tablo Uygulaması:Örnek olarak aşağıdaki gibi Personel isimli tablomuz olsun.
id | Adi_soyadi | Sehir | Bolum | Sicil No |
1 | Salih ESKİOĞLU | İstanbul | Bilgi İşlem Sorumlusu | 1234567 |
2 | Ayhan ÇETİNKAYA | Kocaeli | İdari İşler Yöneticisi | 2345678 |
3 | Serkan ÖZGÜREL | Erzincan | Bilgi İşlem Sorumlusu | 3456789 |
SQL SELECT Kullanımı
Data Tipi | Açıklama | Boyut |
---|---|---|
Text | Metinsel verileri depolar. Girilen sayıları da metinsel olarak depoalr. En fazla 255 karakter alır. | |
Memo | 255 karakterden fazla bilgi depoalamak istenildiğinde kullanılır. 65,536 karakter alır. Not: Bu alanda alfabetik sıralama yapılamaz. Ancak arama işlemleri yapılabilir. | |
Byte | 0 ile 255 arası tam sayılar için kullanılır. Virgüllü sayılar olmaz. | 1 byte |
Integer | -32,768 ve 32,767 arasındaki tam sayılar için kullanılır. Virgüllü sayılar olmaz. | 2 bytes |
Long | -2,147,483,648 and 2,147,483,647 arasındaki tam sayılar için kullanılır. Virgüllü sayılar olmaz. | 4 bytes |
Single | Tek basamaklı virgüllü ifadeler için kullanılır. | 4 bytes |
Double | Çok basamakalı virgüllü ifadeler için kullanılır. | 8 bytes |
Currency | Para birimi için kullanılır. 15 basamaklı tam sayı ve 4 basamaklı kuruş verisi saklanabilir. Not:Hangi ülke para birimini kullanacağınızı seçebilirsiniz. | 8 bytes |
AutoNumber | Otomatik numara alanıdır. Her kayıt eklendiğinde numara 1 artar. Genel olarak 1'den başlar | 4 bytes |
Date/Time | Tarih ve Saat verilerini saklamak için kullanılır. | 8 bytes |
Yes/No | Evet/Hayır, Var/Yok, veya Açık/Kapalı gibi mantıksal verilerde kullanılır. Kodlamada True veya False ifadeleri ile sorgulanabilir. Not: Bu alan boş olarak geçilemez. | 1 bit |
Ole Object | Resim, ses, video gibi iki taban dosyalarını depolamak için kullanılır. | 1 GB'a kadar |
Hyperlink | Web sayfaları dahil olmak üzere diğer dosyalara bağlantılar içerir. |
MySQL Veri Tipleri
MySQL veritabanalrında temelde 3 tane veri tipi vardır: metinsel, sayısal ve tarih-saat.
Metinsel Veri Tipleri:
Metinsel Veri Tipleri:
Data Tipi | Açıklama |
---|---|
CHAR(boyut) | Boyut ile belirtilen uzunlukta boşluklar da dahil olmak üzere karakter depolar. Bu karkterler harf, sayılar ve özel karakterlerden (% , & , + gibi) oluşur. En fazla 255 karakter alır. Belirtilenden az karakter sayısı da girilse belirtilen boyut kadar yer kaplar. |
VARCHAR(boyut) | Boyut ile belirtilen uzunlukta boşluklar dahil olmak üzere karakter depolar. Bu karkterler harf ve sayılardan oluşur. En fazla 255 karakter alır. En fazla boyut ile belirtilen değer kadar karakter girişi olur. Eğer belirtilenden daha az karakter girilirse, girilen karakter kadar yer kaplar. |
TINYTEXT | En fazla 255 karaktere kadar olan boşluklar dahil metinsel ifadeleri saklar. |
TEXT | En fazla 65.535 karaktere kadar olan boşluklar dahil metinsel ifadeleri saklar. |
BLOB | (Binary Long OBjects). Binary yani ikili verilerin saklanacağı durumlarda kullanılır. En fazla 65.535 byte (yaklaşık 64 KB) veri saklanabilir. |
MEDIUMTEXT | 16.777.215 karaktere kadar metinsel ifadeleri depolayabilir. |
MEDIUMBLOB | 16.777.215 karaktere kadar iki kodlama verilerini saklar. |
LONGTEXT | 4.294.967.295 karaktere kadar metinsel verileri depolayabilir. |
LONGBLOB | 4.294.967.295 karaktere kadar ikili kodlama verisi depolayabilir. |
ENUM(x,y,z,....) | 65535 adede kadar, ihtimalli girişlerde kullanılabilir. Giriş önceliğine göre sıralama yapılır. Giriş formatına örenk: ENUM('X','Y','Z','F') |
SET | Yapısı ENUM'a benzemektedir. Ancak 64 taneye kadar giriş yapılabilir. |
Sayısal Veri Tipleri:
Data Tipi | Açıklama |
---|---|
TINYINT(boyut) | -128 ile 127 arasında değer alır. Boyut ile alabileceği sınırı belirtebiliriz. |
SMALLINT(boyut) | -32.768 ile 32.767 arasında değer alır. Boyut ile alabileceği sınırı belirtebiliriz. |
MEDIUMINT(boyut) | -8.388.608 ile 8.388.607 arasında değer alır. Boyut ile alabileceği sınırı belirtebiliriz. |
INT(boyut) | -2.147.483.648 ile 2.147.483.647 arasında değer alır. Boyut ile alabileceği sınırı belirtebiliriz. |
BIGINT(boyut) | -9.223.372.036.854.775.808 ile 9.223.372.036.854.775.807 arasında değer alır. Boyut ile alabileceği sınırı belirtebiliriz. |
FLOAT(boyut,d) | Küçük rakamlı virgüllü ifadeler için kullanılır. Boyut ile sayının virgüllü kısmı dahil alabileceği en fazla miktar belirtilirken d ile virgülden sonra kaç basamak olacağı belirtilir. Boyut değeri en fazla 23 olabilir. |
DOUBLE(boyut,d) | Büyük rakamlı virgüllü ifadeler için kullanılır. Boyut ile sayının virgüllü kısmı dahil alabileceği en fazla miktar belirtilirken d ile virgülden sonra kaç basamak olacağı belirtilir. Boyut değeri en fazla 53 olabilir. |
DECIMAL(boyut,d) | DOUBLE 'ın yetmediği durumlarda, virgüllü ifadeler için kullanılır. Boyut ile sayının virgüllü kısmı dahil alabileceği en fazla miktar belirtilirken d ile virgülden sonra kaç basamak olacağı belirtilir. Boyut değeri en fazla 65 olabilir. Görüleceği üzere FLOAT, DOUBLE ve DECIMAL arasındaki temel fark boyut ile belirtilen basamak sayısıdır. İhtiyaca göre seçim yapılıp kullanılır. |
Tarih-Zaman Veri Tipleri:
Data Tipi | Açıklama |
---|---|
DATE() | Sadece tarih girişi için kullanılır. 'YYYY-AA-GG' şeklinde depolama yapar. '1000-01-01' ile '9999-12-31' arasındaki tarihleri destekler. |
DATETIME() | Tarih ve saat kombinasyonu için kullanılır. 'YYYY-AA-GG SS:DD:SS' şeklinde depolama yapar. '1000-01-01 00:00:00' ile '9999-12-31 23:59:59' arasındaki tarihleri destekler. |
TIMESTAMP() | Depolama biçimi DATETIME() ile aynıdır. Ancak yazdığınız program üzerinden bu alan veri gönderimi yapılmaz. O anki tarih ve saati otomatik olarak ekler. Eğer elle bir tarih-saat eklenecekse o zaman veritipi DATETIME() olarak ayarlanmalıdır. |
TIME() | Sadece saat verisi saklamak için kullanılır. 'SS:DD:SS' (Saat-dakika-saniye) şeklinde saklar. |
YEAR() | 2 veya 4 basamaklı YIL bilgisini saklamak için kullanılır. Dört basamalı verilerde 1901 ile 2155 arası değer saklanır. İki basamaklı verilerde ise 70 ile 69 (1970 ile 2069) değeri saklanır.. |
MS SQL Server Veri Tipleri
Metinsel Veri Tipleri:
Data Tipi | Açıklama | Depo alanı |
---|---|---|
CHAR(boyut) | Boyut ile belirtilen uzunlukta boşluklar dahil olmak üzere karakter depolar. En fazla 8.000 karaktere kadar depolama yapar. Boyut ile belirtilen değerden az veri girilse bile boyut kadar yer kaplar. | Belirtilen boyut kadar. |
VARCHAR(boyut) | Boyut ile belirtilen uzunlukta boşluklar dahil olmak üzere karakter depolar. En fazla 8.000 karakter alır. En fazla boyut ile belirtilen değer kadar karakter girişi olur. Eğer belirtilenden daha az karakter girilirse, girilen karakter kadar yer kaplar. | 2 Byte+girilen karakter kadar. |
VARCHAR(max) | Varchar ile aynı yapıdadır. En fazla 1.073.741.824 adede kadar karakter depolar. | 2 Byte+girilen karakter kadar. |
TEXT | En fazla 2GB'ye kadar metinsel veri depolamak için kullanılır. | 4 Byte+girilen karakter kadar. |
NCHAR(boyut) | En fazla 4.000 karaktere kadar UNICODE veri saklanabilir. Boyut ile belirtilen değerden az veri girilse bile boyut kadar yer kaplar. | Beliritlen boyut x 2 |
NVARCHAR | En fazla 4.000 karaktere kadar UNICODE veri saklanabilir. En fazla boyut ile belirtilen değer kadar karakter girişi olur. Eğer belirtilenden daha az karakter girilirse, girilen karakter kadar yer kaplar. | |
NVARCHAR(max) | NVARCHAR ile aynı yapıdadır. 536.870.912 adede kadar karakter depolar. | |
NTEXT | En fazla 2GB'ye kadar UNICODE veri depolamak için kullanılır. Girilen karakter kadar yer kaplar. | |
BIT | Sadece 0, 1 veya NULL yani boş değer içerir. Boolean yani var-yok, evet-hayır gibi iki değer alması gerek durumlarda kullanılabilir. | |
BINARY(boyut) | Belirtilen boyut kadar binary yani ikili bilgi saklar. En fazla 8.000 karakter depolar. Boyut ile belirtilen değerden az veri girilse bile boyut kadar yer kaplar. | |
VARBINARY | Belirtilen boyut kadar binary yani ikili bilgi saklar. En fazla 8.000 karakter depolar. Eğer belirtilenden daha az karakter girilirse, girilen karakter kadar yer kaplar. | |
VARBINARY(max) | VARBINARY ile aynı yapıdadır. En fazla 2GB'ye kadar veri saklar. | |
IMAGE | Resim dosyalarını saklamak için kullanılır. En fazla 2GB'ye kadar veri saklar. |
SQL Veri Türleri Uzunlukları
Tablo üzerindeki her bir alanın bir veri tipi vardır. Veritabanını tasarlarken hangi alanın hangi veri tipinde olduğunu belirlemek oldukça önemlidir. Daha sonra bir alandan veri çekmek istenirse alanın tipinie göre veri çekmek işlemi gerekecektir.
Aşağıdaki listede genel olarak kullanılan data tiplerini görebilirsiniz.
Data Tipi | Açıklama |
---|---|
CHARACTER(n) | Metin tipinde n ile belirtilen sayı kadar karakter depolar. n ile belirtilenden az karakter girilmiş olsa bile n kadar yer kullanılır. |
VARCHAR(n) or CHARACTER VARYING(n) | En fazla n ile belirtilen kadar karakteryer kaplar. Girilen veri n değerinden az ise sadece girildiği kadar alan kaplar. |
BINARY(n) | Metinsel olarak Binary değerleri n ile belirtilen kadar depolar. n değerinden az karakter girilse de n kadar yer kullanılır. |
BOOLEAN | TRUE - FALSE , VAR - YOK gibi sadece iki durumun varlığında kullanılır. |
VARBINARY(n) or BINARY VARYING(n) | Metinsel olarak Binary değerleri en fazla n ile belirtilen kadar depolar. Veri n değerinden az ise sadece girildiği kadar alan kaplar. |
INTEGER | Tam sayı olarak numarasal değerleri depolar. Virgüllü değerleri kabul etmez. 4 byte alan kaplar. -2.147.483.648 ile 2.147.438.647 arası değerlerde kullanılır. |
SMALLINT | Küçük tam sayı değerlerini depolar. Virgüllü değerleri kabul etmez. 2 byte yer kaplar. -32.768 ile 32.767 arası değerlerde kullanılır. |
TINYINT | Mini tam sayı değerlerini depolar. Virgüllü değerleri kabul etmez. 1 byte yer kaplar. 0-255 arası değerlerde kullanılır. |
BIGINT | Büyük tam sayıları depolamak için kullanılır. Virgüllü değerleri kabul etmez. 8 byte alan kaplar. -2.147.483.648 ile 2.147.438.647 arası değerlerde kullanılır. -9.223.372.036.854.775.808 ile -9.223.372.036.854.775.807 arası değerlerde kullanılır. |
DECIMAL(p,s) | Virgüllü değerlerde kullanılır.. Örneğin: decimal(5,2) ifadesinde toplam 5 tane rakam olduğunu söylenmiş. Bunun 2 tanesi virgülden sonra olaak belirtilmiş. Tam sayı kısmına ise 3 rakam girilebilir. |
NUMERIC(p,s) | DECIMAL veri tipi ile aynı özelliklere sahiptir. Bazı sistemler sadece Numeric alanı kullanır. |
FLOAT(p) | Virgüllü değerleri yuvarlayarak kayıt eder. p ile hafızada tutulmak istenen byte değeri belirtilir. girilen değer 5 byte'tan fazla ise sadece 5 byte'lık kısmı yuvarlanarak kaydedilir. |
REAL | 4 byte yer tutar. Aynı zamanda Float(24) ile aynı işi yapar. Ancak bu tipte virgüllü sayıları aklayabilirsiniz. |
DATE | Yıl, ay, gün olarak tarih depolar |
TIME | Saat, dakika ve saniye olarak veri depolar |
TIMESTAMP | Yıl, ay, gün, saat, dakika ve saniye olarak veri depolar |
MULTISET | A variable-length and unordered collection of elements |
XML | XML tipinde verileri depolar. |
.
1
SQL Data Tipleri(SQL Veri Türleri)
SQL dili veritbanlarındaki tablolara bağlanıp veri eklemek, daha önceden eklenen verileri okumak ve veriler üzerinde işlem yapmak (güncelleme, silme) için kullanılan bir dildir. Sorgulama yapabilmek için öncelikli olarak veritabanımızda ez azından bir tablo olması gerekmektedir. Birden fazla tablo da olabilir. Ancak ister bir tablo olsun isterse birden çok tablo olsun neticede üzerinde işlem yapmak istediğimiz tabloyu belirtmemiz gerekmektedir. Hangi tablo üzerinde çalışacağımız FROM ifadesi ile belirtiriz. Bu ifade SQL sorgulama dilinin temelidir ve hemen hemen bütün SQL sorgularında kullanılmaktadır. Hemen hemen dedik çünkü bazı sorgu ifadelerinde kullanılmaz. Mesela yeni bir veritabanı veya tablo oluştururken FROM ifadesi kullanılmaz. FROM ifadesi sadece var olan verilerde sorgulama yaparken kullanılır.
Tek başına FROM ifadesi tabiki yetmez. FROM ile hangi tablo üzerinde işlem yapacağımız belirtiriz ancak ilgili tabloda ekleme işlemi mi, silme işlemi mi veya güncelleme işlemi mi yaptığımızı da belirtmemiz gerekmektedir. Bunun için belli başlı işlemler için hangi özel komutun kullanıldığını aşağıdaki tabloda görebilirsiniz.
Komut | İşlemi |
Select | Veritabanından verileri okumak için kullanılır. |
Update | Veritabanındaki var olan bir kaydın bilgilerini güncellemede kullanılır. Örneğin yaşadığı şehir alanı İstanbul olanları Ankara'ya çeviremek gibi. |
Delete | Veritabanındaki bir kaydı silme için kullanılır. |
Insert Into | Veritabanına yeni bir kayıt eklemek için kullanılır. |
Create Database | Yeni bir veritabanı oluşturmak için kullanılır. |
Alter Database | Mevcut veritabanı özelliklerinde değişiklik yapmak için kullanılır. |
Create Table | Veritabanına yeni bir tablo eklemek için kullanılır. |
Alter Table | Mevcut tablo özelliklerinde işlem yapmak için kullanılır. Bu komut ile mevcut kayıtlar üzerinde işlem yapılmaz. |
Drop Table | Veritabanı içindeki bir tabloyu silmek için kullanılır. Bu işlem ile ilgili tablodaki kayıtlar da silinir. |
Örnek1:
Select * From Personel (Personel tablosundaki bütün kayıtları çeker.)
Select Ad, Sehir From Personel (Personel tablosunda çok sayıda alan olabilir. Ancak bu komutla sadece Ad ve Sehir alanlarındaki kayıtları çekeriz.)
Yukarıdaki örnekte görüleceği üzere öncelikli olarak hangi işlemin yapılacağı belirtiliyor. Daha sonra ise hangi alanlar için yapılacağı belirtiliyor ve son olarak hangi tablo üzerinde yapılacağı belirtiliyor.
Select Ad, Sehir From Personel (Personel tablosunda çok sayıda alan olabilir. Ancak bu komutla sadece Ad ve Sehir alanlarındaki kayıtları çekeriz.)
Yukarıdaki örnekte görüleceği üzere öncelikli olarak hangi işlemin yapılacağı belirtiliyor. Daha sonra ise hangi alanlar için yapılacağı belirtiliyor ve son olarak hangi tablo üzerinde yapılacağı belirtiliyor.
Örnak2:
Select * From Personel Where Sehir='İstanbul'
Select * From Personel Where Sehir='İstanbul' and Bolum='Bilgisayar'
Select * From Personel Where Sehir='İstanbul' and Bolum='Bilgisayar'
Birinci önekte Personel tablosundan Sehir alanında İstanbul yazan kayıtlar seçilmektedir. Tabloda 100 tane kayıt olabilir. Ancak bunlardan 20 tanesinin Sehir alanında İstanbul yazıyorsa, yazılan bu komut ile sadece 20 tane kayıt seçilip ekrana yazdırılabilir. İkinci örnekte ise Perosnel tablosundaki kayıtlarda Sehir alaninda İstanbul yazan ve Bolum alanında Bilgisayar yazan kayitler seçilip ekrana yazdırılabilir.
Komutların detaylı kullanımları ile ilgili bilgileri sol taraftaki menüden seçerek görebilirsiniz. Bu bölümde temel olarak SQL yapısının nasıl işlediğini anlamanız yeterli olacaktır.
core core server core server kurulumu core server nedir? core server rolleri
,
ms sql nedir
,
sqle giris
.
1
SQL Kullanımı Hakkında
Kaydol:
Kayıtlar
(
Atom
)