c# – 实体框架创建与模型中每个类相对应的单独数据库

我已经开始在ASP.NET MVC4中使用Entity框架了.

我在Model文件夹中创建了3个类,并为每个模型创建了控制器.

现在,当我运行应用程序时,它创建了与每个​​模型类相对应的单独数据库.

有什么办法可以只使用一个数据库吗?

解决方法

您是否为每个类创建单独的上下文?

public class Employee 
{
    [Key] public int EmpId { get; set; } // < Can I make a suggestion here
                                         // and suggest you use Id rather than
                                         // EmpId?  It looks better referring to 
                                         // employee.Id rather than employee.EmpId
    [required] public string Fullname { get; set; }
    ...
}

public class AnotherClass
{
    ...
}

然后在上下文中列出所有模型:

public MyDbContext : DbContext
{
    public DbSet<Employee> Employees { get; set; }
    public DbSet<AnotherClass> AnotherClasses { get; set; }
}

您可能还希望使用Context中的构造函数指定连接字符串名称

public MyDbContext() : base("ConnectionString") {  }

所有模型都在同一个环境中运行非常重要.

使用上下文

var context = new MyDbContext();
var employees = context.employees.ToList(); // I prefer storing the data as an IList

这告诉EF查询数据库并将数据存储在employees变量中.

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...