I've posted my mappings and configuration already. Same goes for teh code, only thing i didn't post is the Classes which i map too. Ill post those now
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace NHibernate2 { public class tEntiteit { private Int32 id; private string name; private IList<Debiteur> debiteurs; public virtual IList<Debiteur> Debiteurs { set { debiteurs = value; } get { return debiteurs; } } public virtual Int32 Id { set { id = value; } get { return id; } } public virtual string Name { set { name = value; } get { return name; } } } } using System; using System.Collections.Generic; using System.Text; namespace NHibernate2 { public class Debiteur { private Int32 id; private string name; private string sorteernaam; private DateTime datumwijzigen; private int actiefneeja; private tEntiteit entiteit; public virtual Int32 Id { set { id = value; } get { return id; } } public virtual tEntiteit Entiteit { set { entiteit = value; } get { return entiteit; } } public virtual Int32 ActiefNeeJa { set { actiefneeja = value; } get { return actiefneeja; } } public virtual string Name { set { name = value; } get { return name; } } public virtual string Sorteernaam { set { sorteernaam = value; } get { return sorteernaam; } } public virtual DateTime DatumWijziging { set { datumwijzigen = value; } get { return datumwijzigen; } } } } On 12 aug, 14:43, Carlos cubas <veno...@hotmail.com> wrote: > Maybe if you show us your configuration file and mapping files we can help > more. > > -Carlos > > Practice makes perfect, but if no one is perfect, why practice? > > > Date: Wed, 12 Aug 2009 05:26:29 -0700 > > Subject: [nhusers] Re: NHIbernate performance vs Entity Framework > > From: folk...@bluenode.nl > > To: nhusers@googlegroups.com > > > Changed the code a little, i'm now creating one session, and one > > factory on the Load. However i use a button_click to trigger the > > actual querying.. > > > First time i click el button it's slow (both the msgbox timer shows 21 > > seconds and profiler tells me 19 seconds) but the second time i hit > > the button (even after clearing th SQL Cache) it runs in less then 5 > > seconds. > > > So it clearly has something to do with the creating of objects or > > something. I'm kind of clueless as to what i'm doing wrong to cause > > the horrible performance i'm having on the first calling > > > On 12 aug, 14:15, "F.B. ten Kate" <folk...@bluenode.nl> wrote: > > > Ow, little extra info, it's 390000 Records i'm querying, which > > > obviously is kinda alot. > > > > On 12 aug, 14:12, "F.B. ten Kate" <folk...@bluenode.nl> wrote: > > > > > Like i said, the "timer" is in SQL Profiler. In otherwords not in the > > > > code, but i also have the following bits in there to compare. > > > > > DateTime start = DateTime.Now; > > > > IList<Debiteur> lijst = session.CreateCriteria(typeof > > > > (Debiteur)).List<Debiteur>(); > > > > DateTime stop = DateTime.Now; > > > > dataGridView1.DataSource = lijst; > > > > > MessageBox.Show((stop-start).Seconds +"."+ (stop- > > > > start).Milliseconds); > > > > > Meaning i start the timer AFTER the session has been created, and > > > > start the "query" if i am getting this. the NHibernate project atm > > > > takes 26 seconds to do this (this is with another enitity added with > > > > Lazyloading, without this entitity it was +- 21 seconds) EF does the > > > > same action in +- 5 seconds. Which leads me to believe the problem > > > > lies in the execution of the SQL. > > > > > On 12 aug, 14:07, Paco Wensveen <pac...@gmail.com> wrote: > > > > > > The sql is not executing slowly, the building of the sessionfactory is > > > > > slow. Start your timer after buildsessionfactory and compare again. > > > > > > On Wed, Aug 12, 2009 at 2:01 PM, F.B. ten Kate<folk...@bluenode.nl> > > > > > wrote: > > > > > > > Yes i am atm, since it's just a quit check to run a query, but would > > > > > > this explain the SQL executing this slowly? > > > > > > > I know i'm not using any "best" practises and things, this is the > > > > > > first thing im doing with both NHibernate and EF. > > > > > > > Here is the code running it. > > > > > > > Configuration cfg = new Configuration(); > > > > > > cfg.Configure(); > > > > > > cfg.AddAssembly(typeof(Debiteur).Assembly); > > > > > > > ISessionFactory factory = cfg.BuildSessionFactory(); > > > > > > ISession session = factory.OpenSession(); > > > > > > > IList<Debiteur> lijst = session.CreateCriteria(typeof > > > > > > (Debiteur)).List<Debiteur>(); > > > > > > > dataGridView1.DataSource = lijst; > > > > > > > On 12 aug, 13:22, Kim Johansson <hagbarddenst...@gmail.com> wrote: > > > > > >> Are you creating a new SessionFactory each run? (SLOOOOOOOOOOOW!!!) > > > > > > >> You should use a single instance SessionFactory and just create new > > > > > >> sessions. > > > > > > >> F.B. ten Kate wrote: > > > > > >> > Hello there, im currently looking at some differences between > > > > > >> > both > > > > > >> > ORM's and to get a good feel for both i try to query from one > > > > > >> > table > > > > > >> > and simply drop all the data in a DataGridView. > > > > > > >> > Easy as pie right? > > > > > > >> > Now here is the different SQL's beeing generated > > > > > > >> > NHibernate: > > > > > > >> > "SELECT this_.Debiteur_ID as Debiteur1_0_0_, this_.Debiteurnaam > > > > > >> > as > > > > > >> > Debiteur2_0_0_, this_.Entiteit_ID as Entiteit3_0_0_, > > > > > >> > this_.Sorteernaam > > > > > >> > as Sorteern4_0_0_, this_.DatumWijziging as > > > > > >> > DatumWij5_0_0_, this_.Actief_NeeJa as Actief6_0_0_ FROM > > > > > >> > tbl_Debiteur > > > > > >> > this_" > > > > > > >> > Enitity Framework: > > > > > > >> > "SELECT > > > > > >> > [Extent1].[Actief_NeeJa] AS [Actief_NeeJa], > > > > > >> > [Extent1].[DatumWijziging] AS [DatumWijziging], > > > > > >> > [Extent1].[Debiteur_ID] AS [Debiteur_ID], > > > > > >> > [Extent1].[Debiteurnaam] AS [Debiteurnaam], > > > > > >> > [Extent1].[Entiteit_ID] AS [Entiteit_ID], > > > > > >> > [Extent1].[Sorteernaam] AS [Sorteernaam] > > > > > >> > FROM [dbo].[tbl_Debiteur] AS [Extent1]" > > > > > > >> > Okay, so sofar EF wins in readability atleast but i dont intend > > > > > >> > to > > > > > >> > actually look at the queries so i'm not worried. > > > > > > >> > I noticed that NHibernate was ALOT slower then EF, the reasons > > > > > >> > seemed > > > > > >> > like a mistery to me so i ran SQL Profiler. > > > > > > >> > When i run the NHibernate project the query runs for a duration > > > > > >> > of > > > > > >> > 19369 (milliseconds) > > > > > > >> > Then i run Enitity frame work which runs for a duration of 3621 > > > > > >> > (milliseconds) > > > > > > >> > (I clear caches between the different queries) > > > > > > >> > I then run the query in SQL Management Studio, The NHibernate > > > > > >> > has a > > > > > >> > duration of 4291 (milliseconds) > > > > > >> > I do the same for the Enitity framework which has a duration of > > > > > >> > 4291 > > > > > >> > (milliseconds) > > > > > > >> > Can anyone explain to me these durations? mostly the NHibernate > > > > > >> > time > > > > > >> > when running it from application code is HUGE. Eventhough the > > > > > >> > SQL is > > > > > >> > exactly the same... --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "nhusers" group. To post to this group, send email to nhusers@googlegroups.com To unsubscribe from this group, send email to nhusers+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/nhusers?hl=en -~----------~----~----~----~------~----~------~--~---