- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的问题在于缺乏MVC经验。基本上,我在数据库中有两个表-人-报价
我为每个人创建了一个模型、一个 Controller 和一个模型,因此结构如下所示:
public class Offer
{
public int OfferID { get; set; }
public string OfferTitle { get; set; }
public string State { get; set; }
public string Description { get; set; }
}
public class OfferDBContext : DbContext
{
public DbSet<Offer> Offers { get; set; }
}
这是报价模型。
public class Person
{
public int PersonID { get; set; }
public string Username { get; set; }
public DateTime Birthday { get; set; }
public string Education { get; set; }
public string Email { get; set; }
}
public class PersonDBContext : DbContext
{
public DbSet<Person> Persons { get; set; }
}
这是 Person 模型。
首先,我创建了 Person 模型,它毫无问题地将自己添加到数据库中。然后我想添加 Offer 表,我不得不使用 DropCreateDatabaseIfModelChanges 方法。我将它用于 OfferInitializer 和 PersonInitializer,然后是 Global.asax.cs 文件
protected void Application_Start()
{
Database.SetInitializer<OfferDBContext>(new OfferInitializer());
Database.SetInitializer<PersonDBContext>(new PersonInitializer());
//Database.SetInitializer<PersonDBContext>(new PersonInitializer());
AreaRegistration.RegisterAllAreas();
RegisterGlobalFilters(GlobalFilters.Filters);
RegisterRoutes(RouteTable.Routes);
}
据我所知,我不能这样做只是因为我删除了数据库 2 次,每次只填充一个表。我如何重新组织这一切,以便我可以一次填充两个或多个表,或者整个数据库?
最佳答案
首先,您不应该为每个表创建单独的 DbContext
类。您应该将所有 DbSets
放在同一个 DbContext
中。这样做会大大简化您的工作。
其次,您应该考虑使用迁移
。您应该在项目的早期就开始使用它们。
您使用包管理控制台处理代码优先迁移。
enable-migrations
顾名思义。初始化项目中的迁移。这将在您的项目中创建一个文件夹并生成所需的文件。
add-migration InitialCreate
这会创建一个迁移。 InitialCreate 实际上是一个字符串,您可以将其更改为任何您想要的。此命令将生成从 strach 创建数据库所需的脚本。
update-database
此命令验证数据库并应用所需的迁移(或迁移 - 可以有多个)以使数据库保持最新。
这是初始设置。如果您对第一个代码优先类做进一步的更改,或者添加更多,您只需添加一个新的迁移然后执行它。
add-migration AddedFirstName
update-database
就这么简单!
还有一些更高级的概念,如种子、回滚、特定迁移的更新等,但我在上面输入的内容涵盖了迁移的基础知识和日常使用。
我建议您阅读这篇文章,它更详细地解释了一切:http://www.asp.net/mvc/overview/getting-started/getting-started-with-ef-using-mvc/migrations-and-deployment-with-the-entity-framework-in-an-asp-net-mvc-application
关于c# - ASP NET MVC 3 - 如何首先使用两个表和 Database.Setinitializer 在代码中重置数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27212391/
我正在尝试使用谷歌浏览器的 Trace Event Profiling Tool分析我正在运行的 Node.js 应用程序。选择点样本后,我可以在三种 View 之间进行选择: 自上而下(树) 自上而
对于一个可能是菜鸟的问题,我们深表歉意,但尽管在 SO 上研究了大量教程和其他问题,但仍找不到答案。 我想做的很简单:显示一个包含大量数据库存储字符串的 Android ListView。我所说的“很
我已经开始了一个新元素的工作,并决定给 Foundation 5 一个 bash,看看它是什么样的。在创建带有水平字段的表单时,我在文档中注意到的第一件事是它们使用大量 div 来设置样式。所以我在下
我有一个 Windows 窗体用户控件,其中包含一个使用 BeginInvoke 委托(delegate)调用从单独线程更新的第 3 方图像显示控件。 在繁重的 CPU 负载下,UI 会锁定。当我附加
我有一堆严重依赖dom元素的JS代码。我目前使用的测试解决方案依赖于 Selenium ,但 AFAIK 无法正确评估 js 错误(addScript 错误不会导致您的测试失败,而 getEval 会
我正在制作一款基于滚动 2D map /图 block 的游戏。每个图 block (存储为图 block [21][11] - 每个 map 总共 231 个图 block )最多可以包含 21 个
考虑到以下情况,我是前端初学者: 某个 HTML 页面应该包含一个沉重的图像(例如 - 动画 gif),但我不想强制客户缓慢地等待它完全下载才能享受一个漂亮的页面,而是我更愿意给他看一个轻量级图像(例
我正在设计一个小软件,其中包括: 在互联网上获取资源, 一些用户交互(资源的快速编辑), 一些处理。 我想使用许多资源(它们都列在列表中)来这样做。每个都独立于其他。由于编辑部分很累,我想让用户(可能
我想比较两个理论场景。为了问题的目的,我简化了案例。但基本上它是您典型的生产者消费者场景。 (我关注的是消费者)。 我有一个很大的Queue dataQueue我必须将其传输给多个客户端。 那么让我们
我有一个二元分类问题,标签 0 和 1(少数)存在巨大不平衡。由于测试集带有标签 1 的行太少,因此我将训练测试设置为至少 70-30 或 60-40,因此仍然有重要的观察结果。由于我没有过多地衡量准
我是一名优秀的程序员,十分优秀!