NHibernate 自引用查询

发布于 2024-09-10 04:02:13 字数 475 浏览 1 评论 0原文

在 NHibernate 中如何写这个?

criteria
    .CreateAlias( "CreatorObject.LastCreated", "me" )
    .Add( Restrictions.Eq( this, "me" ) );

编辑:类似这样,不使用 sql

其中有两个表 TypeA 和 TypeB,其中 typeB 创建 typeA 对象并保留对最后创建的对象的引用。

criteria
.Add( Restrictions.IdEq( Projections.SqlProjection( "(Select LastCreated From Creators Where Creators.Id = CreatorId) as MasterId", new[] { "MasterId" }, new[] { NHibernateUtil.Int32 } ) ) );

How do you write this in NHibernate?

criteria
    .CreateAlias( "CreatorObject.LastCreated", "me" )
    .Add( Restrictions.Eq( this, "me" ) );

Edit: something like this without using sql

Where there are two tables TypeA and TypeB where typeB creates typeA objects and keeps a reference to the last object created.

criteria
.Add( Restrictions.IdEq( Projections.SqlProjection( "(Select LastCreated From Creators Where Creators.Id = CreatorId) as MasterId", new[] { "MasterId" }, new[] { NHibernateUtil.Int32 } ) ) );

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

踏雪无痕 2024-09-17 04:02:13

所以,如果你有类似的东西,

public class SomeClass {
  public SomeClass LastCreated { get; set;}
  public SomeClass CreatorObject {get; set;}
}

你可以写这样的东西:

criteria.Add(Restrictions.Eq("CreatorObject.LastCreated", this));

So if you have something like

public class SomeClass {
  public SomeClass LastCreated { get; set;}
  public SomeClass CreatorObject {get; set;}
}

you could write something like:

criteria.Add(Restrictions.Eq("CreatorObject.LastCreated", this));
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文