开发者

How to return joined objects as result of criteria?

开发者 https://www.devze.com 2023-01-06 18:52 出处:网络
I\'开发者_如何转开发m wondering how I can represent the following in the criteria API return DataContext.Session.CreateQuery(\"

I'开发者_如何转开发m wondering how I can represent the following in the criteria API

return DataContext.Session.CreateQuery("
    select
        ss.PracticeArea 
    from Subsection as ss
    where ss.Location = :Location
    ")
    .SetEntity("Location", location)
    .List<PracticeArea>();

The where clause is straight forward enough the bit I'm tripping over is how to get the joined object as the result ?

DataContext.Session.CreateCriteria<Subsection>()
    .Add(Restrictions.Eq("Location", location))
    .List<PracticeArea>();

This is my attempt which doesnt work since it returns the wrong type.


Try this:

DataContext.Session
    .CreateCriteria<Subsection>()
    .CreateCriteria("Subsecion", "ss")
    // the "select" clause is called "projection"
    .SetProjection(Projections.Property("ss.PracticeArea"))
    .Add(Restrictions.Eq("Location", location))
    .List<PracticeArea>();


I've got the following to work, I don't know if its going to perform better or worse than using a projection?

DetachedCriteria subsections = DetachedCriteria.For<Subsection>()
    .SetProjection(Projections.Property("PracticeArea.Id"))
    .Add(Restrictions.Eq("Location", location));

return DataContext.Session
    .CreateCriteria<PracticeArea>()
    .Add(Subqueries.PropertyIn("Id",subsections))
    .List<PracticeArea>();
0

精彩评论

暂无评论...
验证码 换一张
取 消