当我保存对数据库的更改时,我遇到了以下异常:
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 举报,一经查实,本站将立刻删除。