强制重新创建实体到复杂类型转换的数据库

dur*_*lka 1 .net migration entity-framework ef-code-first

我有一个使用EF(仍在学习它)的WCF服务,以将一些自己的元数据存储在数据库中.在某些时候,我意识到(需求已更改)我不需要为某些类分别使用单独的实体,并希望将它们转换为复杂类型,因为关系是1:1.我不介意重新创建数据库或丢失任何数据,因为没有.

问题是每当我尝试运行应用程序或调用Update-database时,我都会得到"类型'Model.ReportConfig'已经被配置为实体类型.它不能被重新配置为复杂类型." 哪种方式有意义,但我真的不希望它重新配置,但从头开始配置,但即使我删除了所有旧表,甚至在web.config中指定了绝对干净的数据库,我仍然会收到此错误.

顺便说一句.我没有看到任何EdmMetadata表.

这使我对数据完整性的关注感到困惑.有任何想法吗?

EDIT ReportConfig有问题.我的DbContext中没有其他配置(即使我尝试在OnModelCreating中添加modelBuilder.ComplexType();)

[DataContract]
[ComplexType]
//    [Table("UserReportConfigs", Schema = "WebApp")]
public class ReportConfig
{
//        [Key, DatabaseGenerated(DatabaseGeneratedOption.Identity)]
//        public long Id { get; set; }

    [DataMember]
    public string Title { get; set; }

    [DataMember]
    public DateTime From { get; set; }

    [DataMember]
    public DateTime To { get; set; }

    [DataMember]
    public int ReportAs { get; set; }

    [DataMember]
    public string ParamValue { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

EDIT2我将ReportConfig重命名为Configuration,错误消息现在反映了新名称,因此我假设它的元数据试图跟上它可能是错误的.在迁移过程中看起来EF将其注册为实体,然后发现它被标记为ComplexType.

我正在使用5.0.0-rc版本的EF

Die*_*hon 6

确保你DbSet<ReportConfig>的DbContext类中仍然没有,因为这会告诉EF这ReportConfig是一个实体.