LIKE Elemanı 1
Like (layk diye okunur) kelimesinin buradaki anlamının “gibi” olduğunu en baştan bilirsek gerisini anlamamız çok daha kolay olacaktır.
LIKE işleci (operatörü) belirtilen özelliklere uygun metinlerin bulunması için kullanılan, oldukça faydalı ve sık kullanılan bir işleçtir. Bu yüzden konunun üzerinde ayrıntılı olarak duracağım.
LIKE işleci (operatörü) belirtilen özelliklere uygun metinlerin bulunması için kullanılan, oldukça faydalı ve sık kullanılan bir işleçtir. Bu yüzden konunun üzerinde ayrıntılı olarak duracağım.
SQL LIKE Sözdizimi (Syntax)
SELECT kolon_adı(ları) FROM tablo_adı WHERE kolan_adı LIKE desen (pattern)
Yukarıda geçen desen (pattern) kavramını örneklerden sonra daha iyi anlayacaksınız.
Örnek sorgularımız için kullanacağımız Uyeler tablosu:
| uye_adi | isim | soyisim | e-posta | cinsiyet |
|---|---|---|---|---|
| osman.e | Osman | Erol | osman.e@osman.com | E |
| derya.z | Derya | Zar | derya.z@derya.com | K |
| meryem.a | Meryem | Ar | meryem.a@meryem.com | K |
| emre.a | Emre | Aydın | emre.a@emre.com | E |
| levent.d | Levent | Deniz | levent.d@levent.com | E |
Örnek-1: Soyadı “Z” harfi ile başlayan üyeleri seçmek istiyoruz
SELECT * FROM uyeler WHERE soyisim LIKE 'Z%'
Sorgumuzun çıktısı aşağıdaki gibi olacaktır:
| uye_adi | isim | soyisim | e-posta | cinsiyet |
|---|---|---|---|---|
| derya.z | Derya | Zaimoğlu | derya.z@derya.com | K |
Burada desen olarak Z% ifadesini kullandık. Ve bu ifadeyi tek tırnak içerisinde yazdık. Bu desenin anlamı avamca “ilk harfi büyük Z olmalı gerisi ise herşey olabilir” demek.
Örnek-2: Adının son harfi “t” olan üyeleri seçelim:
SELECT * FROM uyeler WHERE isim LIKE '%t'
Sorgumuzun çıktısı aşağıdaki gibi olacaktır:
| uye_adi | isim | soyisim | e-posta | cinsiyet |
|---|---|---|---|---|
| levent.d | Levent | Deniz | levent.d@levent.com | E |
Örnek-3: İsminin içerisinde “er” ifadesi geçen üyeleri bulalım:
SELECT * FROM uyeler WHERE isim LIKE '%er%'
Sorgumuzun çıktısı aşağıdaki gibi olacaktır:
| uye_adi | isim | soyisim | e-posta | cinsiyet |
|---|---|---|---|---|
| derya.z | Derya | Zar | derya.z@derya.com | K |
| meryem.a | Meryem | Ar | meryem.a@meryem.com | K |
‘%’ karakterinin sıfır, bir yada daha çok karakterin yerine geçebilen bir joker karakter olduğu herhalde örneklerden anlaşılmıştır.
Örnek-4: Şimdi de isminin içerisinde “er” ifadesi geçmeyen üyeleri bulalım:
SELECT * FROM uyeler WHERE isim NOT LIKE '%er%'
| uye_adi | isim | soyisim | e-posta | cinsiyet |
|---|---|---|---|---|
| osman.e | Osman | Erol | osman.e@osman.com | E |
| emre.a | Emre | Aydın | emre.a@emre.com | E |
| levent.d | Levent | Deniz | levent.d@levent.com | E |
Görüldüğü gibi NOT ifadesi seçimi tersine çevirmek için yeterli oluyor.
Buraya kadar LIKE operatörüne genel bir giriş yapmış olduk. Bir sonraki yazıda LIKE ile joker karakterlerin kullanımına ayrıntılı olarak bakacağız.
Hiç yorum yok:
Yorum Gönder