Neden Poco?

Thursday, June 09, 2011 12:00 PM

Geçen hafta okumaktan zevk aldığım ALT.NET guruba bir başlık açmıştım. Neden poco? Gökhan ERCAN arkadaşımızın verdiği cevap konuyu gayet iyi anlatan bir cevap olmuştu.

 

POCO entity'leri mevcut kullanılan ORM'ye ya da diğer bir dış sisteme ait referans barındırmadığı için sistemdeki mevcut komponent'lerin hepsinden soyutlanmış olacaktır. Bu da üretilen entity'lerin daha kolay test edilmesi, daha saf olarak serialize edilmesi, daha az yer kaplaması ve hiçbir kütüphaneye bağımlılığı olmadan farklı sistemler arasında dağıtılabilmesi gibi avantajlar getirecektir. İleride ORM değiştirebilmek ve aynı entity'lerin farklı ORM kullanan sistemler arasında sorunsuz paylaşabilmesi gibi avantajları olacaktır. 

 

Dezavantaj olarak ise; mimarinin her katmanında temel data kontratları olarak kullanılan entity'lerin direk olarak veriyi ilgilendiren ChangeTracking, LazyLoading, Datatype Validation, Serialization, Databinding gibi konularda tamamen bilgisiz olması ve bu konuda kendiliğinden bir destek verememesidir. Bu özellikleri dış servislerden dinamik ya da statik proxy'ler üreterek çözmek mümkün ama her entity kullanımında 1-2 satırlık ekstra kod getirecek ve dinamik çağrımlar yapacağı için belirli bir oranda performansı düşürebilecektir.. Ayrıca POCO'ya dinamik proxy'ler ile servisler sağlarken tüm property'lerin public, virtual olması, ctor almaması, abstract olmaması gibi kısıtlamalar gelecektir. Bunlar da dezavantaj sayılabilir. "

Etiketler Poco Orm

Yorumlar

Yorum Eklenmemiş...

Yorum Yaz

Adınız: *
E-Mail Adresiniz: *
Web Sitesi:
Yorum: *