28 Haziran 2015 Pazar

Temel SQL Dersi 8: LIKE Elemanı 2



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 KarakterAçı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_adiisimsoyisime-postacinsiyet
osman.eOsmanErolosman.e@osman.comE
derya.zDeryaZaimoğluderya.z@derya.comK
meryem1990MeryemArkadaşmeryem.a@meryem.comK
emre.aEmreAydınemre.a@emre.comE
levent.dLeventDenizlevent.d@levent.comE


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_adiisimsoyisime-postacinsiyet
meryem.aMeryemArmeryem.a@meryem.comK


_ 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_adiisimsoyisime-postacinsiyet
osman.eOsmanErolosman.e@osman.comE


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