Resultados en aplicaciones reales usando NHibernate Reflection Optimizer
Quizás algunos van a pensar que esto es una aplicación usando NHibernate, pero la verdad es que no. Como es una aplicación sin NHibernate me las arreglé para convertir DataTables resultados de consultas a objetos de Negocio o colecciones de objetos para poder manejarlos fuera de la capa de Infraestructura de una manera más interesante.
La capa de Infraestructura posee unos helpers para realizar la conversión que nombramos usando algunas convenciones, attributes y reflection! Llega la hora de la optimización y tenemos que afrontar que Reflection no es algo de lo que se debe abusar, pero tampoco está prohibido.
En este post mostraba alguna de las bondades de NHibernate como buen ORM y las optimizaciones que posee a la hora de instanciar objetos, o setear/obtener los valores de las properties o fields.
Los Helpers de datos básicamente están encargados de convertir Datatables a Colecciones de Entidades o simplemente a Entidades. Para esto podemos tener métodos como ser: GetEntities y GetEntity
Las pruebas se hicieron realizaron la misma cantidad de consultas y con los mismo datos en la base. El profiler para realizar las pruebas es DotTrace, de la empresa JetBrains.
Sin optimizaciones:
Con Optimizaciones (NHibernate Reflection Optimizer)
53 llamadas a GetEntities: 111,18 ms. contra los 66,921 ms. del GetEntities con las optimizaciones. Destaquemos aquí que GetEntities solamente realiza conversiones para obtener colecciones y objetos de negocios, y no realiza ninguna hit a la base de datos.
-
Categories
- .NET
- ActiveRecord
- agil
- Alt.Net
- AOP
- Asp.net MVC
- blog
- C#
- codegeneration
- cosas interesantes
- db4o
- db4o-analyzer
- DLR
- enterprise-library
- expresiones regulares
- General
- Hibernate
- IoC
- it
- Java
- LINQ
- Linux
- Lucene
- Mocking
- Mono
- monosms
- MVC
- NAnt
- NHibernate
- NHibernate.Burrow
- NHibernate.Contrib
- NHibernate.Validator
- noticias
- O/R Mapping
- Open Source
- patrones
- personal
- podcast
- programación
- Redes Neuronales
- Refactoring
- regex
- Scrum
- Security
- Shards
- Sin Categoría
- Spring
- SqlServer
- Testing
- tips
- Tool
- tutorial
- Ubuntu
- uNHAddIns
- video
- Virtualización
- Visual Basic.Net
- Visual Studio
- VMWare
- Web
-
Articles
- June 2011
- May 2011
- November 2009
- October 2009
- April 2009
- March 2009
- February 2009
- October 2008
- September 2008
- August 2008
- July 2008
- June 2008
- May 2008
- April 2008
- March 2008
- February 2008
- January 2008
- December 2007
- November 2007
- October 2007
- September 2007
- August 2007
- June 2007
- May 2007
- April 2007
- March 2007
- February 2007
- January 2007
- December 2006
- November 2006
- October 2006
- September 2006
- August 2006
- March 2006
- February 2006
- December 2005
- November 2005
- October 2005
-
Meta




