LIKE Elemanı 2
Joker Karakterler
Bir veya birden fazla karakterin yerine geçebilen karakterlere joker karakter diyoruz. Aslında joker karakter kavramı bilgisayar dünyasında sıkça kullanılan bir kavramdır. Ortama göre gösterimde ufak tefek değişiklikler olsa da genel mantığı aynıdır. SQL dilinde joker karakterleri yalnızca LIKE işleci ile birlikte kullanıyoruz. SQL için tanımlanmış joker karakterler aşağıdaki gibidir:
| Joker Karakter | Açıklama |
| % (MS Access için * kullanılır) | Sıfır, bir veya daha fazla sayıda karakterin yerine geçebilir. |
| _ (MS Access için ? kullanılır) | Bir adet karakterin yerine geçebilir. |
| [liste] | Listedeki karakterlerden herhangi biri |
| [^liste]Veya
[!liste]
| Listedede olmayan karakterlerden herhangi biri Ya da listede olan karakterlerden hiçbirisi. (iki açıklama da aynı kapıya çıkıyor) |
Tablomuzu çağıralım;
| uye_adi | isim | soyisim | e-posta | cinsiyet |
|---|---|---|---|---|
| osman.e | Osman | Erol | osman.e@osman.com | E |
| derya.z | Derya | Zaimoğlu | derya.z@derya.com | K |
| meryem1990 | Meryem | Arkadaş | meryem.a@meryem.com | K |
| emre.a | Emre | Aydın | emre.a@emre.com | E |
| levent.d | Levent | Deniz | levent.d@levent.com | E |
Bir önceki yazıda % Joker karakterinin kullanımına dair örnekler yapmıştık. Bir örnek daha yapalım.
Adı “M” ile başlayıp “m” ile biten üyeleri görmek istersek:
SELECT * FROM uyeler WHERE isim LIKE 'M%m'
Sorgumuzun çıktısı aşağıdaki gibi olacaktır:
| uye_adi | isim | soyisim | e-posta | cinsiyet |
|---|---|---|---|---|
| meryem.a | Meryem | Ar | meryem.a@meryem.com | K |
_ veya ? Joker karakteri
Bu karakter standart SQL için “_” (alt-tire) MS Access için de “?” olarak tanımlanmıştır. Ben örneklerde “_” olarak kullanacağım.
Şimdi aşağıdaki sorguyu ve çıktısını inceleyelim:
SELECT * FROM uyeler WHERE uye_adi LIKE 'osman_e'
Sorgunun çıktısı aşağıdaki gibi olacaktır:
| uye_adi | isim | soyisim | e-posta | cinsiyet |
|---|---|---|---|---|
| osman.e | Osman | Erol | osman.e@osman.com | E |
Eğer tablomuzda uye_adi alanında osmanRe, osman+e, osman5e gibi kayıtlar olsaydı, bunlar da bu sorgudan dönen tabloda yer alacaklardı.
LIKE ‘_a_’ : Üç harfli ortadaki harfi “a” olanlar.
LIKE ‘ m_s_n’ : mısın, musun, müsün veya muson gibi bir çok kelime bu desene uyuyor. Ancak muusun gibi bir kelime bu desene uymaz. Bu karakter yerine yalnızca bir adet karakter gelebileceğini tekrar hatırlatalım.
Karakter Listeleri
Karakter listeleri ise yukarıdaki işlemleri yalnız bir grup karakter için tanımlamak istediğimizde kullanılır:
LIKE ‘c[ai]n': Bu desen can ve cin kelimelerini kapsar.
Örneğin ismi erhan, ercan, erkan veya erman olan üyeleri getirmek isteseydik:
SELECT * FROM uyeler WHERE uye_adi LIKE 'er[hckm]an'
sorgusu işimizi görürdü. Adı E veya K harfi ile başlamayan üyeleri seçmek isteseydik:
SELECT * FROM uyeler WHERE uye_adi LIKE '[^EK]%'
sorgusu yeterli olurdu. Aynı sorguyu Access için yazmak istesek LIKE’tan sonraki kısım ‘[!EK]*’ şeklinde olacaktı.
Önemli Not: MySQL’de LIKE yerine RLIKE (veya REGEXP) işleci kullanılıyor.
Hiç yorum yok:
Yorum Gönder