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自动执行强制转换。
这篇关于必需属性,但可以为空,通过代码优先的实体框架的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:必需属性,但可以为空,通过代码优先的实体框架
基础教程推荐
- .NET SerialPort DataReceived 事件未触发 2022-01-01
- 我应该在后面的代码中直接使用 Linq To SQL 还是使 2022-01-01
- 当值可以是对象或空数组时反序列化 JSON 2022-01-01
- 如果有人提交恶意软件Nuget包怎么办? 2022-01-01
- Moq It.Is<>不匹配 2022-01-01
- C# 从 List<List<int>> 中删除重 2022-01-01
- 禁止输入少量字符,例如'<'、'&a 2022-01-01
- WPF 模态进度窗口 2022-01-01
- 如何使用 .Net 检查 Active Directory 服务器是否已启动并正在运行? 2022-01-01
- Azure Functions:CosmosDBTrigger 未在 Visual Studio 中触发 2022-01-01
