2

如果您愿意,请考虑Order具有集合属性的类的示例OrderLines

public class Order
{
    public OrderLineCollection OrderLines { get; private set; }
}

现在考虑一个数据访问层,它返回一个Order没有填充属性的对象OrderLines集合(空集合)。

为了尽量减少到服务器的往返行程,系统将所有 Order 对象的 id 传递给 DAL,DALOrderLine一次性返回每个 Order 的对象。业务规则层中的代码负责将正确OrderLine的对象添加到正确的Order对象中。

public class OrderDAL
{
    public IEnumerable<Order> GetOrdersByCustomer(int customerId)
    {
        ...
    }

    public IEnumerable<OrderLine> GetOrderLines(IEnumerable<int> orderIds)
    {
        ...
    }
}

这是做这种事情的一般方式(减少数据库往返)吗?

DAL 是否应该负责返回完全填充的Order对象?

有没有更好的方法?

不,我不能在这个特定的实例中使用 ORM 工具!

4

1 回答 1

1

我一个不。我不想在初始查询后返回商店检索更多数据。加载数据时,您(应该)知道要在什么环境下加载数据,因此您会事先知道要在什么“导航属性”或连接上进行。这样一来,您就可以获得所需的所有数据。

然而,这是从无状态的角度来看的,因为我目前专注于 MVC 和实体框架。我想如果您正在创建一个会计程序,您可能有一个显示订单标题的订单屏幕和一个您想要显示所选订单详细信息的订单详细信息屏幕。所以在这种情况下,是的,只需要检索所选订单的 OrderLines 会很有用。

像往常一样,答案是:视情况而定。

不,我不能在这个特定的实例中使用 ORM 工具!

为什么?

于 2013-05-16T11:40:29.663 回答