我正在尝试使用一对一映射将旧用户表拆分为两个实体,但继续收到迁移错误,指出我的数据库不同步,即使所有内容(我认为已映射)并且我正在尝试制作一对一的关系。
这是一个现有的数据库(虽然我首先使用代码,因为迁移将变得非常重要)但我没有对数据库添加任何更改(尽管我不确定一对一表拆分的确切内容),我一直这样:
The model backing the 'Context' context has changed since the database was created. Consider using Code First Migrations to update the database
我可以更新数据库(手动或通过迁移),但不知道实际上不同步的是什么,因为没有添加新字段且名称匹配。
BaseEntity:
public abstract class BaseEntity<T>
{
[Key]
public T Id { get; set; }
public DateTime CreatedOn { get; set; }
}
会员模型:
public class Membership : BaseEntity<Guid>
{
public string UserName { get; set; }
public bool Approved { get; set; }
public bool Locked { get; set; }
public Profile Profile { get; set; }
}
个人资料模型:
public class Profile : BaseEntity<Guid>
{
public string FirstName { get; set; }
public string LastName { get; set; }
public string Email { get; set; }
public string Telephone { get; set; }
public string Extension { get; set; }
public Membership Membership { get; set; }
}
成员资格映射(具有1对1定义):
public class MembershipMap : EntityTypeConfiguration<Membership>
{
public MembershipMap()
{
//Primary Key
this.HasKey(t => t.Id);
//**Relationship Mappings
this.HasRequired(m => m.Profile)
.WithRequiredPrincipal(p => p.Membership);
//Properties & Column mapping
this.Property(m => m.Id)
.HasColumnName("PKID")
.HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);
this.Property(m => m.UserName)
.HasColumnName("Username")
.HasMaxLength(255);
this.Property(m => m.Approved)
.HasColumnName("IsApproved");
this.Property(m => m.Locked)
.HasColumnName("IsLocked");
this.Property(m => m.CreatedOn)
.HasColumnName("CreationDate");
this.ToTable("AppUser");
}
}
个人资料映射:
public class ProfileMap : EntityTypeConfiguration<Profile>
{
public ProfileMap()
{
//Primary Key
this.HasKey(t => t.Id);
//Properties & Column mapping
this.Property(m => m.Id)
.HasColumnName("PKID")
.HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);
this.Property(m => m.FirstName)
.HasColumnName("FirstName");
this.Property(m => m.LastName)
.HasColumnName("LastName");
this.Property(m => m.Email)
.HasColumnName("Email");
this.Property(m => m.Telephone)
.HasColumnName("Telephone");
this.Property(m => m.Extension)
.HasColumnName("Extension");
this.ToTable("AppUser");
}
}
数据库表 我知道并非所有字段都已映射,但在此阶段我不需要它们,当然这不是问题吗?
答案 0 :(得分:0)
问题不是Code First Mappings,而是由我切换数据库和一些胭脂迁移引起的。
要重置迁移,您可以在后续问题中找到答案:
向EvilBHonda致敬