实体框架:虽然列具有默认值,但必须进行映射?

Adr*_*ore 8 t-sql sql-server entity-framework

我正在尝试基于旧版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
Run Code Online (Sandbox Code Playgroud)

但该列似乎绑定了默认值0.我尝试对数据库运行此SQL语句:

ALTER TABLE [dbo].[Users] ADD  DEFAULT ((0)) FOR [NewsletterSubscribed]
Run Code Online (Sandbox Code Playgroud)

但那也失败了:

消息1781,级别16,状态1,行3列已经绑定了DEFAULT.消息1750,级别16,状态0,行3无法创建约束.查看以前的错误.

所以要么列没有默认值(在这种情况下我不知道为什么我不能创建一个),或者Entity Framework没有看到它.到底是怎么回事?

谢谢,

阿德里安

Jul*_*ain 12

使用Visual Studio XML编辑器而不是使用实体设计器打开.edmx,并将DefaultValue="0"属性添加到SSDL中未映射的列.由于某些原因,这些不是从数据库生成的.