本文介绍了必需属性,但可以为空,通过代码优先的实体框架的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
如何使属性成为必需的(用于字段验证),但对于数据库代码迁移可为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自动执行强制转换。
这篇关于必需属性,但可以为空,通过代码优先的实体框架的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!