假设我有一个名为Products
的表的数据库。因此,我使用Db First方法在VS 2012中使用pluralize and singularize
选项创建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
代码复制到它,并将视图作为视图模型传递给它。然后,当我想查询我的数据库时,我会得到一个异常,说明数据库中不存在dbo.ProductModels
名称......
提前致谢
答案 0 :(得分:3)
默认情况下,数据库优先方法将始终将表名映射到同名实体(可能是复数/单数化)。目前EF中没有规定通过惯例或工具进行调整。您可以更改/调整/自定义模型 - 但如果重新生成模型,则会丢失这些更改。我不知道任何工具/脚本/黑客以某种方式“保留”这些更改并在从数据库重新生成模型后重新应用它们。
如果您需要扩展生成的我建议使用部分类的事实 - 您可以在第二个物理文件中扩展生成的类:< / p>
将其写在单独的文件中,例如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;}
//...
}