Kategoriler


SON YORUMLAR
Taha
Hocam elinize , kaleminize sağlık çok güzel bir yazı olmuş.
Tatar Ramazan
Anlo-Saksonlar (İngiliz, Amerika), Almanlar, Fransızlar, Ruslar, Yahudiler dünyanın en başarılı milletleri. Genleri dolayısıyla öyle. Osmanlının zirve döneminde bile sanat ve bilimde bizden ileriydiler. Rönesans 1450den sonra başladı. Bizim zirve dönemi 1600lü yıllardı. Osmanlı bile daha zeki diye Avrupadan adam getirdi. Türkiyede bile başarılı, düzgün, elit insanların önemli bir bölümü muhacırdır. Geçmişte Yunanistan, Bulgaristan, Makedonya, Romanya, Bosna gibi yerleri feth edebildik. Bu ülkelerden şimdi de ileriyiz zaten. Fransa, Cermenler, İngilizler, Ruslar oralara üstünlük kuramadık. Bugün de yine o milletler bizden maddi anlamda ileri. Yani değişen bir şey yok. Japonlara, Çinlilere ve Hindulara gelince.. Teknoloji, bilim, buluş gibi alanlarda yukarıda saydığım kavimler yapıyor çoğu şeyi. Japonlar buluş yapmıyor. Var olanı küçültüyor. Tasarım yapıyor. Sony markasının reklamı bile vardı 12 sene önce. En küçük fotoğraf makinesini, kamerayı, bilmem ne cihazını biz yaptık falan filan. Amerikanın eşek gibi çalıştırdığı köleler. Ehli kitap (Hristiyanlar, yahudiler) ve müslümanlar her zaman putperest kavimlerden üstündür. Bunu unutmayın. Maddi ilerlemenin dinle, dinsizlikle alakası yok. Çalışan kazanır.
Hüseyin
Kafamdaki çoğu soruya cevap buldum teşekkürler...
Samet
Makaleyi harika buldum .Çok işime yaradı. Teşekkürler.
Tatar Ramazan
Saatte 1500 satır kod yazmayan kendini camdan aşağı atsın. Almanya 1. ve 2. dünya savaşı öncesi 10-20 senede süper güç olmuştu. Sıkı ve disiplinli çalıştılar çünkü. Biz 90 senede bir savaş uçağı yapamadık. Atatürkçüler suçu islama, Osmanlıya attılar. Kemalist Türkiye niye bi halt olamadı o zaman? Kendin çalışma, okuma, bir şey becereme ondan sonra dinde kabahat ara. Sümme haşa!
Gamze
C#, C++, ASP.NET-MVC, HTML-CSS, Matlab, Arduino ödevleri, web sitesi yapılır. Bilgi için; gamze.zirh@gmail.com
Seda
web sitesi, masa üstü uygulamaları, muhasebe, restaurant, otel, barkot sistemleri yazılımı yapılır. adres:s.sedaerden@gmail.com
Hafize
Yazılım ödevleri ve web sitesi yapılır.Bilgi için hafizearduc@hotmail.com
Tatar Ramazan
Temam geldi
Dilara
Doğru yazdığıma eminim
Tatar Ramazan
Kopyala elle yazma yanlış yazdın. Gelmedi
Tatar Ramazan
Gördüm şimdi
Dilara
Attim
Tatar Ramazan
İlle mühendislik diyorsun demek. O halde sana iyi yazılımcı olmanın yolunu göstereyim. Bunu sen istedin. kambozlusaban@hotmail.com babamın mail adresi. Mesaj at. Atınca da buraya yaz attım diye.

Bilgisayar Mühendisleri
Here is the website inspired me to use 
it as a guide when I tried to define 
myself as an engineer candidate a few 
years ago. It really helped me to work
 and study feeling in confidence with 
being on the right way. I suggest this 
website to whom it may direct her/his 
to find the right career path. It 
includes many articles varies from 
real life experiences to detailed 
software engineering issues. But the 
most dignified parts for me are the 
articles in general and career titles.
Son okunan makaleler:
NHibernate için Veri Erişim Katmanını Otomatik Oluşturma
Türkiye İşlemcisini Tasarlıyor Yarışmasına 103 Başvuru
Bilgisayar Mühendisleri Kaç Para Alır?
Von Neumann mimarisi
Bill Gates Emekli Oldu
Bilgisayar Mühendisliği Hakkındaki 10 Büyük Yalan!
Dizin (Directory) ve LDAP (Lightweight Directory Access Protocol) Kavramları
PHP Geliştirme Ortamı - Zend Studio
Staj Yeri Nasıl Bulunur? Staja hazırlık olarak neler yapmalıyım?
Bilgisayar Mühendisi Ne İş yapar? Program Nedir? Çeşitli Sorular?
Bilgisayar Mühendisleri Kaç Para Alır?
Para ile ödev yapmak üzerine
Bilgisayar Mühendisleri Kaç Para Alır?
Bilgisayar Mühendisi Ne İş yapar? Program Nedir? Çeşitli Sorular?
Staj Yeri Nasıl Bulunur? Staja hazırlık olarak neler yapmalıyım?
Bilgisayar Mühendisleri Kaç Para Alır?
Bilgisayar Mühendisleri Kaç Para Alır?
Bilgisayar Mühendisleri Kaç Para Alır?
ViewState İçeriğini Sıkıştırmak
Bilgisayar Mühendisleri Kaç Para Alır?

Bilgisayar Mühendisleri Portalı

NHibernate için Veri Erişim Katmanını Otomatik Oluşturma

NHibernate için Veri Erişim Katmanını Otomatik Oluşturma

Enterprise yazılım geliştirme projelerinde rol alan yazılımcıların sık karşılaştığı sorunlardan biri, birden fazla veritabanı destekli kod geliştirmekdir. Neden veritabanı bağımsızlığı; Sql Server 2000 tabanlı yazılım geliştirirseniz, müşterileriniz "Bende Oracle varken neden Sql Server kullanayım" der ya da tersi, siz Oracle'da geliştirirsiniz, müşterileriniz "Ben Oracle lisansına para veremem, maliyeti yüksek" tepkisi verebilir.

Bu durum .Net'den önce Java zamanında farkedilmiş ve çeşitli çözümlerle aşılmıştır. Bu çözümlerden en yaygın ve kullanışlı olanı ana amacı bizi relational yapıdan kurtarmak olan ORM (Object Relation Mapping) yazılımları kullanmaktır.

ORM detaylı bir konu olduğu için girmeden yüzeysel bu çeşit toolların temel birkaç getirisini inceleyelim:

  • Tek kodla, kodu değiştirmeden kullandığınız ORM tool'unun desteklediği tüm veritabanlarını otomatik siz de desteklemiş olursunuz. Tabi bundan böyle stored procedure olayını unutup VIEW kullanmaya ağırlık vermeniz gerekmektedir. Sorgu cümlelerinizi zaten ORM toolu otomatik kendisi oluşturur.
  • Kodlama aşamanızda Tablo/Row yapılı DataSet gibi relational sistemler yerine tablonun içerdiği mantıksal nesnelerle işlemlerinizi yaparsınız, yani kodlama felsefeniz relational yapı yerine nesneye yönelik bir yapıya döner. Örneğin; relational yapıdaki KULLANICI ismindeki tabloya KULLANICI_ADI "ali" olan yeni bir satır INSERT etme olayı nesnel yapıda KULLANICI nesne kolleksiyonuna ismi "ali" olan yeni bir KULLANICI nesnesi ekleyip değişiklikleri kaydetmek şeklinde yorumlanabilir.
  • Dinamik değişken parametreli sorgularda geliştirme hızınız çok artar. Örneğin ana ekranınızda 10 farklı parametreli bir filtre olsun. Kullanıcı bu filtrelerden istediklerini seçebilir olsun ve her seçtiği filtre sorguya dahil edilmeli olsun. Bunun için ya kendiniz kod tarafında select sqllerinizi oluşturursunuz ki zahmetlidir ve birden fazla veritabanı desteliyorsanız işiniz çok daha zorlaşır, yada dolu olsun olmasın tüm parametreleri stored procedure'e yollarsınız tüm kombinasyonlarla o başa çıkar ki bu daha da zordur, sproc'da SELECT stringi oluşturup çalıştırmanız gerekir. ORM toollarında ise Where'den sonra şunları ekle demek yeterlidir, hedef veritabanına uygun sql'i kendisi oluşturur.
  • Veri erişim katmanınız çoğu ORM toolu tarafından otomatik oluşturulur, çok daha az kodla veritabanı işlemlerinizi gerçekleştirirsiniz ve okunurluğu daha yüksekdir.

Konumuza dönersek; çoğunuzun bildiği gibi Java tarafında bir numaralı ORM toolu Hibernate'dir, .Net tarafında ise 50'den fazla ORM toolu piyasaya sürülse de Hibernate kadar büyük çaplı olan bir tane şu an için yok. Ama benim kişisel tercihim piyasada da en yaygın olanları NHibernate ve Llblgen 'dir (Lblgen çok kolay kullanımlı, pratik ve templatelerini kendisi hazırlayan hoş bir program olsa da lisans ücreti var).

Şu an mevcut olan NHibernate 1.0.2, Java'daki Hibernate 2.1'in .Net uyarlaması olmasına karşın Hibernate'in 3.2 sürümüne kadar gelmiş olması bu konuda Java'cıları geriden takip ettiğimizin göstergesi. NHibernate'in malesef kendisine ait bir otomatik kod oluşturma mekanizması yok. Yani normalde veri erişim katmanını NHibernate için kendimizin hazırlaması gerek ve bunun için de her sınıf (object/relational birebir yapıda bir sınıf bir tabloya karşılık gelir) için bir XML mapping dosyası bir de .Net sınıfına ihtiyacınız var (sınıfları ayrı dosyalara böldüğümüzü farzedersek kullanıdğınız dile bağlı olarak örneğin c# için .cs uzantılı ayrı bir dosya gerek).

Eğer veritabanını tablo yapısından nesnel bir yapıya çevirmek istemiyorum, tablolarla nesnelerin birebir eşleştirildiği bir yapıyı yazılım otomatik oluştursun diyorsanız, piyasada bu işi yapan pek çok yazılım var. Bunlardan bazıları kendi başına bağımsız yazılımlar şekline yapılmış bazıları da CodeSmith (ücretli) ve MyGeneration (ücretsiz) gibi yazılımlar için template şeklinde hazırlanmıştır.

 

 

Sonuç; benim ekte verdiğim kod da MyGeneration için bir templatedir. Yaptığı iş de veri erişim katmanını Visual Studio 2003 yada 2005 için ayrı bir c# projesi olarak otomatik oluşturmaktır (relational yapıyla birebir eşleşen nesne yapısı oluşturur). Yazdığım template k-dub, Gustavo ve spunlogic'in templateleri üzerine yazılmıştır. Yaptığım değişiklikler:

  • Visual Studio 2003 ve 2005 için proje dosyalarını otomatik oluşturma özelliği eklendi
  • Lisans mesajı kutusu eklendi
  • Binary kolon desteği eklendi
  • View'lar için sahte primary key atama özelliği eklendi
  • NHibernate ile bir select işlemi yaptıktan sonra IsChanged flagının bozulmasına önlem olarak nhibernate kullanımı için ayrı property tanımlama özelliği eklendi
  • MarkAsDeleted, IsChanged ve IsDeleted fonksiyonları lazy loading modunda virtuala dönüştürldü (NHibernate 1.2.0 Alpha 1 uyumluluğu için)
  • Birkısım eksik double atamaları eklendi.
  • Spunlogic'in kaydetindeki bir hata giderildi
  • Türkçe i/ı karakter sorunu çözüldü
  • Viewlardaki çift kolon tanımı hatası giderildi
  • Viewler salt-okunur yapıldı
  • Varolan bir proje dosyasının üzerine yazım yaptığınızda Source Safe gibi kod kontrol yazılımlarının kullandığı tagların eski proje dosyasından yeni proje dosyasına taşınması gerçekleştirildi

Dosyayı MyGeneration'ın sitesine de "Serdar's NHibernate Object Mapping 1.2" tanımı ile gönderdim: http://www.mygenerationsoftware.com/TemplateLibrary/Template/?id=158a7d34-a15e-40f9-8399-255f8f85f76c

Burada en büyük artı tabiki artık proje dosyalarını da otomatik oluşturabilmesi, düzeltilen en önemli hata da Türkçe sistemlerde bu tamplateleri kullanırken karşılaştığımız en ciddi sorun olan isimlendirmelerdeki Türkçe büyük "I" harfinin küçük "i" yerine küçük "ı"ya dönüşmesiydi.

Yapmanız gereken işlem kabaca; MyGeneration'ı indirip kurup bu template'i kullanarak veri erişim projesini oluşturup solution'ınıza eklemek ve NHibernate'i indirip bin dizinindekileri kendi bin dizinizine kopyalayarak dökümanına göre gerekli ayarlamaları yapmakdır.

 serdar_nhibernate.zip (14K)

.


   ©2006-2007 Serdar Irmak serdar@argelab.net
http://www.argelab.net

Bu makaleyi beğendin mi? Yorumunu Yaz!







Sizden Gelen Yorumlar:

Yorum Yazın

Maho(22.7.2011 09:01:19)
Güzel bi makale sağol
%0 %0 %0
Katılıyorum Çekimserim Katılmıyorum



Serdar(25.6.2009 12:37:46)
2 sene öncesinin makalesi olduğu için yeni gelişmelerle yazılanların bir kısmı geçerliliğini yitirdi.
%67 %17 %17
Katılıyorum Çekimserim Katılmıyorum






Copyright© 2001-2018. Bilgisayar Mühendisleri Portalı | Bütün hakları saklıdır.