微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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; }

问号使该属性可以为空

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐