ORM Nedir?
ORM, Object Relational Mapping anlamına gelmektedir. O/R Mapping olarakta yazılabilir. ORM nedir diye bir soru soracak olursak şöyle bir cevap verebiliriz: “İlişkisel veritabanı (RDBMS) ile nesneye yönelik programlanın (OO) arasında bir tür köprü özelliği gören ve ilişkisel veritabanındaki bilgilerimizi yönetmek için, nesne modellerimizi kullandığımız bir tekniktir/metodtur”. Basite indirgemek istersek: “Nesnelerimizi ilişkisel veritabanındaki tablomuza bağlayan ve veri alış-verişini bizim için yapan bir tekniktir/metodtur”. ORM tekniği belli bir programlama diline bağlı değildir ve her OO dilinde yazılabilir/kullanılabilir.Günümüzde kullanılan popüler programlama dillerinde yazılmış bir çok ORM kütüphaneleri vardır. Bunlara çoğu zaman ORM araçları (ORM Tools) deniyor. Yazımın ilerleyen bölümlerinde Java dünyasında kullanılan popüler ORM araçlarına bir göz atacağız.
ORM Kullanmanın Avantajları
- Nesneye yönelik bir programlama metodu sunuyor
- Yazılan kodun veritabanı çeşidiyle bağımlılığı yok (Oracle, SQL Server, MySQL vs)
- SQL/JDBC bilmenize/yazmanıza gerek kalmadan çok kısa bir zamanda ve de çok daha az kod ile veritabanına bağlı bir uygulama yapabilirsiniz
- ORM araçlarının çoğu Open Source (Açık kaynak kodlu – yani bedava)
- ORM araçları, programcılara bir çok kolaylık sağlıyor ve içinde barındırdığı ek desteklerle bir çok sık görülen sorunlara çözüm sunuyor. (polymorphism, caching, transaksiyon, vs)
- Sektör içinde kullanılan Java ürünlerinin çoğunda popüler ORM araçları için ekler mevcuttur (Spring, Eclipse, vs)
- Otomatik kod üretmek ve ya SQL üretmek için bir çok ürün mevcuttur
- Çok daha iyi test edilebilir kod yazmamızı sağlar
ORM Kullanmanın Dezavantajları
- Performans sorunları
- Bilgi alış-verişi sırasında kontrolün yüzde yüz sizin elinizde olmaması (Üretilen SQL bazen çok farklı olabilir)
- Kullanılan ORM aracını öğrenmek için harcanan zaman
ORM aracı seçiminde dikkat edilmesi gerekenler nelerdir?
Öncelikle şunu belirtmek gerekir ki, ORM aracı kullanmak kesinlikle mecburi bir şey değildir. Uygulamanızı JDBC ve SQL ile de yazmayı seçebilirsiniz. Fakat ORM aracı kullanmazsanız yukarıda belirtilen avantajlardan yararlanamayacaksınız ve JDBC ile programlamanın getirdiği zorlukları, kendiniz çözmek zorunda kalacaksınız. Ama yine de, ORM aracı kullanmamak ta avantajlı olabilir. Peki ne zaman kullanıp kullanmayacağımızı nasil bilebileceğiz. Altta, değişik bakış açıları ile bu soruya cevap vermeye çalıştım.- Uygulamanızın büyüklüğü
Büyük uygulamalar: Eğer uygulamanız küçük değilse, kesinlikle bir ORM aracı kullanmanızı tavsiye ediyorum. ORM araçlarının sunduğu tüm olanaklara emin olun ihtiyacınız olacaktır. Sadece, hangi ORM aracını seçmeniz gerektiğini düşünmeniz gerekecek. Bunu da, uygulamanızın gereksinimlerine ve ORM araçlarının sunduğu özelliklere bakarak yapmanız çok doğru olacaktır. Mesela uygulamanız distributed bir ortamda çalışacaksa caching/clustering desteği sağlayan bir ORM aracı seçmeniz uygun olacaktır.
- Uygulamanızın performansı
Bir başka neden ise ORM aracının yanlış kullanılmasıdır. Bunun en büyük örneklerinden biri, Lazy loading özelliğinin doğru kullanılmamasıdır. Lazy loading, bazı bilgilerin veri çekme sırasında değilde, gerektiği zaman alınmasını belirten bir seçenektir. Eğer lazy loading seçeneğini doğru kullanmazsanız, her seferinde istemediğiniz bir çok bilgiyi veritabanından çekmiş olacaksınız. Tabiki bu da performansın düşmesine sebep olacaktır.
Tabiki bazen de ORM aracı içerisinde çözülemeyen performans sorununu, JDBC kullanıp çözmekten başka seçenek kalmayabilir. Böylelikle tam istediğiniz gibi bir SQL yazabilirsiniz. Fakat ORM aracı ile JDBC aynı anda kullanıyorsanız, caching ve nesne durumlarında sorun olup olmamasına dikkat edin. Mesela ORM aracı içinde bulunan bir nesne, sizin tarafınızdan JDBC ile değiştirilmiş olabilir.
Uygulamamızın dışında, veritabanınızın doğru tasarlanmış olup olmaması da performans için çok büyük bir önem taşıyor. Örneğin, indexlerin nerelerde kullanıp kullanılmadığına bir göz atın. Veya veritabanı makineninizin özellikleride önemli olabilir. Bağlantı havuzunuzdaki özelliklere de bakabilirsiniz.
- Projenin bitmesi gereken zaman birimi
ORM’de Mapping Nedir?
Mapping, ORM’de veritabanı ile nesnelerimiz arasındaki bağı kuran yapımızdır. Hangi nesnenin (sınıfın) hangi tabloyla bağlanacağını, bağlanan tablolarda hangi property’nin (özelliğin ya da değişkenin) tablonun hangi alanıyla bağlanacağını, tablonun özelliklerini (ID’sinin ne olduğu, ID’sinin autoincrement olup olmadığı vb.) bilgilerin tanımlandığı yapımızdır. Kimi ORM frameworkleri bu işlemi yazılımcının yapmasını istese de (Hibernate, Nhibernate) kimi frameworkler bu işlemleri kendisi gerçekleştirmekte, istediği taktirde yazılımcının mapping’de düzenleme yapmasına izin vermektedir (Entity Framework).Aşağıdaki şekilde, Orm’nin yapısı daha net anlaşılmaktadır.
ORM Aracı Kullanımında Önemli Tavsiyeler
- Lazy loading özelliğini iyi bir şekilde kullanın. Örnek olarak, her zaman çekilmesi gerekmeyen verileri lazy olarak çekin.
- Caching mekanızmasını iyi anlayın ve gereksinimlere gore değiştirin.
- Çok karmaşık ORM sınıf modelleri yapmaktan kaçının.
- Şunu kabul etmek gerekir ki, ORM araçları her soruna çözüm sağlamıyor. Bu nedenle bazen normal SQL kullanmak ta olağan birşeydir.
- Veritabanınızdaki tablo şemanızı en iyi şekilde tasarlayın ki, nesne modeliniz ona göre uygun ve performanslı çalışsın. Kötü tasarlanmış bir veritabanı şeması, hangi ORM aracı seçilirse seçilsin efektif şekilde çalışmaz. Tavsiyem veritabanınızı iyi bir DBA (DataBase Administrator) tarafından kontrol ettirmeniz.
- Verileri çekerken mümkün olduğu sürece pagination (sayfalandırma) kullanmaya çalışın. Böylelikle tüm bilgileri bir anda almanıza gerek kalmamış olacak.
- Transaksiyon, concurrency batch processing ve locking mekanızmalarını, yazılımınıza en uygun şekilde configure edin.
- ORM aracı kullanırken iki tür yöntemle başlıyabilirsiniz. İlki önce veritabanı hazırlanıp ardından java sınıfları hazırlanır/üretirilir. İkincisi de önce java sınıfları hazırlanıp, ardından veritabanı tasarlanır/üretilir. Ben şahsen önce veritabanı hazırlayıp, sonra java kodlarını yazıyorum/üretiyorum. Veritabanı çok önemli olduğu için, kontrolün bende olmasını istiyorum. Java sınıflarını yazarken de, bazen otomatik kod üreten program kullanıyorum, bazen de tüm sınıfları kendim yazıyorum. Tavsiyem, polymorphism veya karmaşık modeller kullanmak istiyorsanız sınıfları kendiniz hazırlanamanızdır.
Sonuç
ORM araçları, proje geliştirmede çok büyük bir destek sağlamaktadır. Veritabanı işlemlerinin karmaşıklığını bizim için gizler ve veritabanindan bağımsız olarak nesne modelimize karşı çalışmamızı sağlar. Fakat yanlış kullanıldığında ise kabusumuz olabilir ve değişik sorunlarla karşılaşabiliriz. O yüzden de kullandığınız ORM aracının tüm inceliklerini ve püf noktalarını öğrenmek için gayret etmenizi tavsiye ederim. İnternette tüm popüler ORM araçları hakkında tonlarca dokümantasyon var ve bunun yanında da bir çok yazılımcı kendi tecrübelerini paylaşmaktadır. Bunları takip etmenizi şiddetle öneriyorum.
Kaynak : http://www.barisdere.com/
Kaynak : http://www.barisdere.com/
No comments:
Post a Comment