当我保存对数据库的更改时,我遇到了以下异常:
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; }
问号使该属性可以为空