1

我有一个具有相应子级的标准类别域实体。即类别及其对应的子类别。这如下所示。真的很标准的东西。

public class Category : Entity
{
    private IesiCollections.ISet<Category> _children;

    public Category()
    {
        _children = new HashedSet<Category>();
    }

    public virtual string Name { get; set; }
    public virtual string Description { get; set; }
    public virtual Category Parent { get; private set; }
    public virtual ICollection<Category> Children { get { return _children; } }

    public virtual bool AddCategory(Category category)
    {
        if (category != null && _children.Add(category))
        {
            category.SetParent(this);
            return true;
        }

        return false;
    }

    public virtual bool RemoveCategory(Category category)
    {
        if (category != null && _children.Remove(category))
        {
            category.SetParent(null);
            return true;
        }

        return false;
    }
}

我正在使用 NHibernate 分析器来确保一切都以最佳方式运行。但是,当我通过调用“RemoveCategory”方法并传入一个类别来删除子类别时,它必须访问名为“_children”的底层集合,该集合会启动“_children”集合的延迟加载。

这会在 NHProf 中导致“Unbounded result set”警报,这是有道理的,因为我们没有指定限制。它将加载整个集合。我想指定一个限制,因为这个集合可能会变得非常大。

我已经查看了 nhprof 网站上关于无限结果的示例(如下所示),但我看不到如何使用它。

var order = session.Get(orderId);
var orderLines = session.CreateFilter(order.OrderLines, "")
    .SetFirstResult(0)
    .SetMaxResults(25)
    .List();

DoSomethingWithOrderLines(orderLines);

当我们显示数据但我想更新我的实体并最终保留它时,这似乎很有用。关于如何指定集合的​​延迟加载限制的任何想法?

亲切的问候

穆罕默德

4

1 回答 1

0

您可以通过执行以下操作完全避免访问 Children 属性:

category.Parent = null;

我意识到这只是一种解决方法,但如果这就是您所需要的,这是最简单的解决方案。

于 2011-06-26T08:07:06.153 回答