微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 存储库模式和导航属性

我只想知道编写存储库方法的最佳实践.问题是决定编写上下文没有延迟加载的存储库.如果它是GetById,你如何命名你的方法,但不清楚导航包含在实体中.

所以我想编写像GetUserByIdIncludedPosts这样的方法名称或者最好使用延迟加载激活的上下文?

如果我在方法名称中编写包含的属性,那么对于很少的导航属性来说,这将是非常烦人的长方法名称

解决方法

我在我的存储库基类中使用以下内容,以允许检索实体以及用户指定的依赖关系/关系列表:
protected DbSet<T> Objects { get; private set; }
protected YourDatabaseContext Context { get; private set; }

public virtual T GetByID( int id,params string[] children )
{
    if( children == null || children.Length == 0 )
    {
        return Objects.SingleOrDefault( e => e.ID == id );
    }
    DbQuery<T> query = children.Aggregate<string,DbQuery<T>>( Objects,( current,child ) => current.Include( child ) );
    return query.SingleOrDefault( e => e.ID == id );
}

代码使用EF4 / CTP5,因此使用Db *类,但转换回正常的EF4类(例如ObjectSet而不是DbSet)是微不足道的.

这将使用如下:

var product = productsRepository.GetByID( 42,"Category","Orders.OrderLines" );

这将获取一个产品,其中填写了分类和订单以及所有订单,他们的订单已经急切加载.

原文地址:https://www.jb51.cc/csharp/99126.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐