Bu yazımda sizlere SQL hakkında bazı ipuçları vereceğim. SQL gerçekten mükemmel bir dil. Normal bir programlama diliyle yapabildiğimiz her şeyi SQL ile yapabiliyoruz. Veritabanından çektiğimiz verilerin mutlak değerini almak, karekökünü almak, Convert işlemi uygulamak ve bunun gibi birçok işlemi SQL ile yapabiliyoruz.
Bu konu için aslında çoğu programcının başına gelen bir problemden bahsedeyim. Bu problem, SQL Server ile Visual C#.NET’in farklı tarih formatları kullanması ile oluşan bir problemdir. (Bazılarınızın gülümsediğini hissediyorum :)) Bu problem .NET’in tarih formatının "dd.MM.yyyy" olması, SQL Server’in tarih formatının ise "MM.dd.yyyy" olması ile ortaya çıkar. Bunu çözmek için önceden (aslında şimdi de) C#’da
string tarih = DateTime.Now.Month.ToString() + "." + DateTime.Now.Day.ToString() + "." + DateTime.Now.Year.ToString();
string tarih = DateTime.Now.ToString("MM.dd.yyyy");
System.Globalization.CultureInfo culture =
new System.Globalization.CultureInfo("en-GB");
string tarih = Convert.ToDateTime(txtTarih.Text, culture);
gibi ifadeler kullanıyordum. Eminim ki birçoğunuz da bunlara benzer şekillerde bir çözümler bulmuştu. Ama bu çözümler SqlDataSource’da otomatik olarak oluşturduğumuz update ve insert cümlelerinde pek fazla işe yaramaz. (Tabi siz insert ve update alanlarını TemplateField olarak ayarlayıp kod tarafında işlem yapmak isterseniz bunları kullanabilirsiniz) Bu sorunun SQL ile çözümü ise
INSERT INTO TABLO(kisi, tarih)
VALUES(@kisi, CONVERT(datetime, @tarih, 103))
şeklindedir. Burada CONVERT() fonksiyonu, gelen parametreyi herhangi bir SQL veri tipine çevirmemize yarar. 103 ise "dd/MM/yyyy" tarih formatını belirtmemize yarar. Bu kısma 108 girdiğimizde saat değerini elde ederiz. ("HH.mm.ss") Biz burada SQL Server’a hangi formatta veri gönderdiğimizi belirtiyoruz. O da hangi formatta olduğunu anlayıp o şekilde işlem yapıyor. Eğer formatını belirtmezsek
“The conversion of a char data type to a datetime data type resulted in an out-of-range datetime value.The statement has been terminated.”
gibi bir hata ile karşılaşırız.
Tarih formatlamanın Oracle’daki karşılığı ise TO_DATE() fonksiyonudur. Bu şekilde girilen bilgiyi tarih bilgisine dönüştürüp Oracle’a kaydedebilirsiniz. Ayrıca Oracle’da tarihe göre arama yapabilmek için bu fonksiyonu kullanmak zorundasınızdır. Kullanılışı ise
TO_DATE(@tarih, 'dd.MM.yyyy')
şeklindedir.