2

我目前正在开发一个应该高度模块化的 MVC 项目。例如,我想要一个用户模块、一个菜单模块和一个页面模块。

因为这些模块需要在不同的 Visual Studio 解决方案中高度可重用,所以我为每个模块创建了单独的项目。

对于数据库映射,我想使用实体框架。我在每个模块项目中创建了一个单独的 DbContext。每个 DbContext 都包含与模块关联的实体。

不幸的是,我不能让 EF 在不同模块/dbContexts 中的实体之间创建外键。

例如:核心模块包含用户实体页面模块包含页面实体,其作者链接到核心模块dbContext中定义的用户实体。

有谁知道如何跨模块/dbContexts 创建外键?

4

1 回答 1

2

您的所有实体都在同一个数据库中吗?我建议像这样分离你的程序集:

数据- 包含您的实体框架模型和/或类/实体定义的项目(取决于您使用的 EF 方法类型)。

服务- 包含操作数据的接口和类的项目。例如,对于您的 User 实体(和相关项目),您可能有这个:

public interface IUser : IDisposable
{
    Data.User Get(int userId);
    IQueryable<Data.User> GetAll();
    //other method definitions for User entity CRUD
}

然后,您执行:

public class User : IUser
{
    private readonly DataEntities _dataContext = new DataEntities(); //this is from your EF Data assembly

    public Data.User Get(int userId)
    {
        return _dataContext.Users.FirstOrDefault(u => u.UserId == userId);
    }

    public IQueryable<Data.User> GetAll() 
    {
        return _dataContext.Users;
    }

    //other method implementations

    public void Dispose()
    {
        _dataContext.Dispose();
    }
}

然后,在您的模块项目中引用您的Service和程序集。Data

于 2014-03-07T14:43:55.170 回答