我正在尝试基于旧版SQL Server 2008数据库创建Entity Framework 4模型。由于该模型将在Web服务中发布,因此我需要省略一个名为NewsletterSubscribed的整数列,该列来自模型的一个实体。
删除EF设计器中的列后,出现以下编译错误:
Error 59 Error 3023: Problem in mapping fragments starting at line 356:Column Users.NewsletterSubscribed in table Users must be mapped: It has no default value and is not nullable.
C:\Users\Adrian\Documents\Sites\Zeiterfassung\Zeiterfassung\API\V1\EFModel.edmx 357 15 Zeiterfassung
但该列似乎有一个默认值0绑定到它。我尝试对数据库运行此SQL语句:
ALTER TABLE [dbo].[Users] ADD DEFAULT ((0)) FOR [NewsletterSubscribed]
但那也失败了:
Ms 1781,Level 16,State 1,Line 3 列已经绑定了DEFAULT 它。 Msg 1750,Level 16,State 0,Line 3无法创建约束。看到 以前的错误。
因此,该列没有默认值(在这种情况下,我不确定为什么我不能创建一个),或者实体框架没有看到它。发生了什么事?
谢谢,
阿德里安
答案 0 :(得分:12)
使用Visual Studio XML编辑器而不是实体设计器打开.edmx,并将DefaultValue="0"
属性添加到SSDL中未映射的列。由于某些原因,这些不是从数据库中生成的。