必需属性,但可以为空,通过代码优先的实体框架

人气:427 发布:2022-10-16 标签: asp.net-mvc c# entity-framework ef-code-first entity-framework-migrations

问题描述

如何使属性成为必需的(用于字段验证),但对于数据库代码迁移可为Null?

我确实有一个包含一千个条目的DB表。最近需要添加必需的DateTime属性。

    [Required]
    [Display(Name = "Birth", Order = 10)]
    public DateTime? Birth { get; set; } 

如果我设置了[Required]注释,代码优先迁移将在列声明中添加NOT NULL。然而,并不是所有当前条目都有"出生"数据。并且它将为空。

Birth属性应该是视图字段validatoin所必需的,但它在数据库中也可以为空。这有可能吗?

我已经尝试添加"?"(可为Null)设置为该属性,但未成功设置为"虚拟"。

推荐答案

使用您的模型进行数据库/实体通信。

为您的用户界面层使用视图模型。在ViewModel中的属性上标记为Required,在模型上标记为Null。根据需要在代码中执行强制转换。将所有与UI相关的属性装饰(如显示、验证等)也移动到ViewModel。

可以通过NuGet包管理器使用AutoMapper插件available自动执行强制转换。

982