2

我的数据库中有这两个表,并且正在为此示例使用实体框架

在此处输入图像描述

我定义了以下 IRepository 接口

public interface IRepository<T> where T:class
    {
        void Add(T entity);
        void Update(T entity);
        void Delete(T entity);
        IQueryable<T> GetAll();
        T Find(int id);
    }


 public class LINQRepository<T> : IRepository<T> where T: class
    {

        protected DbSet DbSet;


        public LINQRepository(DbContext context)
        {
            DbSet = context.Set<T>();

        }

        void IRepository<T>.Add(T entity)
        {
            DbSet.Add(entity);
        }

        void IRepository<T>.Update(T entity)
        {
            DbSet.Attach(entity);
        }

        void IRepository<T>.Delete(T entity)
        {
            DbSet.Remove(entity);
        }

        IQueryable<T> IRepository<T>.GetAll()
        {

            return DbSet as IQueryable<T>;
        }


        T IRepository<T>.Find(int id)
        {

            return DbSet.Find(id) as T;

        }


    }

在我的代码中,我正在实例化一个 QuestionsRepository,并且我还想获​​得返回的问题列表的所有相关答案。我想知道什么是完成这项工作的好方法?我是否在界面中创建另一个功能,例如GetAllWithChild(String ChildName)?我想有更好的方法来解决这个问题。

4

1 回答 1

3

在 getAll 方法中,您必须返回 DbSet 并在调用该方法时。您必须使用 Include(扩展方法)。由于延迟执行的优势,您的查询将被触发一次,您将获得您想要的任何东西..

你必须使用这样的东西

new QuestionsRepository().GetAll().Include("Answers").ToList();

或者

new QuestionsRepository().GetAll().Include(x => x.Answers).ToList();
于 2013-09-21T03:29:54.667 回答