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

Required property but Nullable, Entity Framework through Code First(必需属性,但可以为空,通过代码优先的实体框架)

本文介绍了必需属性,但可以为空,通过代码优先的实体框架的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

如何使属性成为必需的(用于字段验证),但对于数据库代码迁移可为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自动执行强制转换。

这篇关于必需属性,但可以为空,通过代码优先的实体框架的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

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

基础教程推荐