我正在为 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
包含相同Bar
和Baz
孩子的实体。我知道如何通过 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
,也许?)来获取重复条目。不要丢弃它们并接收不同的东西。我只想要完全相同的副本。