c# – Entity Framework 6 Code First插入时的第一个默认日期时间值

前端之家收集整理的这篇文章主要介绍了c# – Entity Framework 6 Code First插入时的第一个默认日期时间值前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
当我保存对数据库的更改时,我遇到了以下异常:
Cannot insert the value NULL into column 'Registered',table
'EIT.Enterprise.KMS.dbo.LicenseEntry'; column does not allow nulls.
INSERT fails. The statement has been terminated.

相关代码第一个模型属性如下所示:

[DatabaseGenerated(DatabaseGeneratedOption.Identity),DataMember]
public DateTime         Registered          { get; private set; }

……这就是为什么我感到困惑:据我所知,通过提供注释[DatabaseGenerated(DatabaseGeneratedOption.Identity)我命令实体框架自动生成字段(在这种情况下:在创建时只有一次) .)

所以我期望有一个不可为空(必需)的字段,没有可能在EF处理的情况下手动改变字段.

我究竟做错了什么?

笔记:

>我不想使用Fluent-API,因为我想使用POCO.
>属性defaultValuesql也不是一个选项,因为我需要依赖该项目的数据库(例如GETDATE()).
>我正在使用Entity Framework 6 alpha 3,Code First.

解决方法

试试这个:
[DatabaseGenerated(DatabaseGeneratedOption.Identity),DataMember]
public DateTime?            Registered          { get; private set; }

问号使该属性可以为空

猜你在找的C#相关文章