Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 3288036
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 17, 20262026-05-17T20:33:41+00:00 2026-05-17T20:33:41+00:00

I have a parent entity with a list of child entities. When using NHibernate

  • 0

I have a parent entity with a list of child entities. When using NHibernate to retrieve a given parent with children from SQL, it works fine if there are no children OR if there are children with dates that match the where condition.

If there are children that do not match the where clause, the parent is null. I want to have the parent initialized with an empty list of children.

Any thoughts on how I can modify the code below to make this happen?

Entities:

public class Parent
{
    public int ParentId;
    public IList<Child> Children { get; set; }

    public Parent()
    {
        Children = new List<Child>();
    }
}

public class Child
{
    public int ChildId;
    public DateTime ChildDate;
    public Parent Parent { get; set; }
}

Repository:

IList<Parent> foundParents = new List<Parent>();

var criteria1 = DetachedCriteria.For<Parent>()
    .Add(Restrictions.Eq("ParentId", parentId))
    .CreateCriteria("Children", JoinType.LeftOuterJoin)
        .Add(Restrictions.Or(
            Restrictions.IsNull("ChildDate"), // no children at all
            Restrictions.And(
                Restrictions.Ge("ChildDate", startDate),
                Restrictions.Le("ChildDate", endDate)
            )
        ));

foundParents = Session
    .CreateMultiCriteria()
    .Add<Parent>(criteria1)
    .SetResultTransformer(new DistinctRootEntityResultTransformer())
    .List()[0] as List<Parent>;

If I were writing SQL for this, I would put the date comparison in with the left join and not in the where clause. I can’t figure out how to do this with NHibernate.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-17T20:33:42+00:00Added an answer on May 17, 2026 at 8:33 pm

    This took alot of research – the key to finding an answer is the term filter. I came across the term by digging through the NHibernate source code starting with AddJoin in ANSIJoinFragment.cs – the code supported additional conditions on the join so I figured it was possible.

    Anyway, here’s the revised code that utilizes filter (entity class remains the same).

    Repository:

    IList<Parent> foundParents = new List<Parent>();
    
    var criteria1 = DetachedCriteria.For<Parent>()
        .Add(Restrictions.Eq("ParentId", parentId))
        .CreateCriteria("Children", JoinType.LeftOuterJoin);
    
    Session.EnableFilter("dateFilter")
        .SetParameter("startDate", startDate)
        .SetParameter("endDate", endDate);
    
    foundParents = Session
        .CreateMultiCriteria()
        .Add<Parent>(criteria1)
        .SetResultTransformer(new DistinctRootEntityResultTransformer())
        .List()[0] as List<Parent>;
    

    I also had to modify my mapping for Parent by adding filter and filter-def elements.

    <class name="Parent" table="Parents">
    
      ...
      <bag name="Children" table="Children">
        ...
        <filter name="dateFilter" 
          condition="ChildDate BETWEEN :startDate and :endDate" />
      </bag>
    </class>
    
    <filter-def name="dateFilter">
      <filter-param name="startDate" type="System.DateTime" />
      <filter-param name="endDate" type="System.DateTime" />
    </filter-def>
    

    Also, one word of warning for anyone that runs into this problem and doesn’t use filters. If you decide to return the Parent entity without the populated children when the original query with the where clause yields no records, any code that hits the set of children will cause NHibernate to load the entire table.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a parent entity in my model Event. And two child entities: Birthday,
I have a Parent entity with 2 child entities ( Foo and Bar )
I have two entities types: RunContainer parent entity type Run child entity type Run
I have a one-to-many mapping between a parent entity and child entities. Now I
I have two entities, Parent and Child, in Entity Framework. The parent has a
I am attempting to save(insert) a Parent entity with list Child entities. Both entites
Using Nhibernate and Fluent NHibernate for the mapping, I have a parent entity with
When I have a parent Entity hold a list of other entity (one to
Say I have an parent entity, each of which have a number of children.
I use Entity Framework 4 and I have parent - child relation with Cascade

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.