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

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自动执行强制转换。

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

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)