entity-framework – 如果EF 5,如何定义自定义命名约定
假设我有一个名为Products的表的数据库.所以,我通过Db First方法在VS 2012中使用复数和单一化选项创建EF模型. 因此,模型为我创建了一个Product实体,默认命名约定将此实体映射到dbo.Products表. 现在我想改变这种行为.实际上我想创建一个自定义约定来将ProductModel实体映射到dbo.Products表. 这可能吗?!如果是这样,怎么样? 更新:我的目标是…… 如您所知,每当您从数据库更新模型时,如果它导致模型发生更改,则自动生成的实体将被覆盖. 另一方面,我想将数据注释属性添加到实体属性,以便我可以使用它们来塑造我的视图,并希望简单地使用我的DbContext,如下面的插入: public ActionResult Create(Product product) { if (ModelState.IsValid) { db.Products.Add(product); db.SaveChanges(); return RedirectToAction("Index"); } return View(product); } 问题是我的应用程序分析没有完成,数据库更改次数.因此,我需要从数据库更新模型,之后,我的所有属性都将被删除. 所以我决定创建一个ProductModel类并将Product代码复制到它,并将视图作为视图模型传递给它.然后,当我想查询我的数据库时,我会得到一个异常,它说db中不存在dbo.ProductModels名称… 提前致谢 解决方法默认情况下,数据库优先方法将始终将表名映射到同名实体(可能是复数/单数化).目前EF中没有规定通过惯例或工具进行调整.您可以更改/调整/自定义模型 – 但如果重新生成模型,则会丢失这些更改.我不知道任何工具/脚本/黑客以某种方式“保留”这些更改并在从数据库重新生成模型后重新应用它们.如果你需要扩展生成的我建议使用那些是部分类的事实 – 你可以在第二个物理文件中扩展生成的类: 将其写在单独的文件中,例如ProductExtension.cs: public partial class Product { // add your custom methods etc. here } 构成该类的各种文件将由C#编译器合并为一个类. 如果需要向现有生成的类添加数据注释,可以使用MetadataType(..)属性as shown in this SO question and its answers: 将其写在单独的文件中,例如ProductExtension.cs: [MetadataType(typeof(ProductMetaData))] public partial class Product { } 然后在另一个文件ProductMetadata.cs中定义产品类的元数据/数据注释,如下所示: public class ProductMetaData { [Required] public int RequestId {get;set;} //... } (编辑:百色站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 如何单元测试我的asp.net-mvc控制器的OnActionExecuting方法
- asp.net – 动态创建和共享Google云端硬盘文件夹
- asp.net-mvc – 从Api控制器内生成绝对的url to action
- asp.net核心 – 如何排除在ASP.NET Core中发布文件?
- asp.net-mvc-4 – MVC4捆绑GZIP和头文件
- WPAD查询从ASP.NET调用webservice
- asp.net+js 实现无刷新上传解析csv文件的代码
- asp.net – 如何从TableAdapter中检索存储过程返回值
- asp.net – 测试Oracle存储过程的最简单的方法
- asp.net – 有没有一个原因,cshtml不受欢迎
- 用户控件在asp.net和Performance中
- asp.net-mvc – ASP.NET MVC检查Controller或Act
- asp.net – 使用app_offline.htm使应用程序脱机,
- .net – CS0012:类型’System.Data.Linq.DataCo
- asp.net – Visual Studio – 为什么.ASPX文件比
- ASP.NET自带对象JSON字符串与实体类的转换
- ASP.net WebAPI跨域调用问题的解决方法
- ASP.NET学习CORE中使用Cookie身份认证方法
- ASP.NET web.config中数据库连接字符串connectio
- asp.net – 我如何使用AJAX来确定用户的会话是否