1

我正在为 SQL Server 2012 和 IQueryOver使用 NHibernate3.3.1.4000和 FluentNHibernate1.3.0.733

我有下一节课:

class Foo {
  public virtual int Id;
  public virtual Bar Bar;
  public virtual Baz Baz;
}
class Bar {
  public virtual int Id;
}
class Baz {
  public virtual int Id;
}

我想选择所有Foo包含相同BarBaz孩子的实体。我知道如何通过 LINQ 查询(IQueryable)在理论上做到这一点

IList<Foo> fooData = Session.Query<Foo>.GroupBy(x => x, new DistinctItemComparer()).Where(g => g.Count() > 1).Select(g => g.Key).ToList();

class DistinctItemComparer : IEqualityComparer<Foo> 
{
    public bool Equals(Foo x, Foo y)
    {
        return (x.Id == y.Id) || ((x.Bar.Id == y.Bar.Id) && (x.Baz.Id == y.Baz.Id)); 
    }

    public int GetHashCode(Foo obj)
    {
        return obj.Id.GetHashCode() ^ obj.Bar.Id.GetHashCode() ^ obj.Baz.Id.GetHashCode();
    }
}

但我得到了错误:

无法解析表达式 'value(NHibernate.Linq.NhQueryable`1[Foo]).GroupBy(x => x, value(DistinctItemComparer))':方法 'System.Linq.Queryable.GroupBy' 的重载当前不是支持的。

因此,也许存在其他解决方案(使用IQueryOver,也许?)来获取重复条目。不要丢弃它们并接收不同的东西。我只想要完全相同的副本。

4

1 回答 1

1

这应该有效:

var fooData = (from foo1 in Session.Query<Foo>()
               from foo2 in Session.Query<Foo>()
               where foo1.Id != foo2.Id 
                     && foo1.Bar.Id == foo2.Bar.Id 
                     && foo1.Baz.Id == foo2.Baz.Id
               select foo1).Distinct().ToList();
于 2013-01-16T18:37:19.720 回答