識別關鍵在我的EF6代碼第一種模式,我有以下類:EF不是關係
class User : IdentityUser // so it has public string Id!
{
public virtual long ItemId { get; set; }
public virtual Item Item { get; set; }
}
class Item
{
public virtual long Id { get; set;
public virtual string UserId { get; set; }
public virtual User User { get; set; }
}
,並在我的情況下,我做了以下內容:
OnModelCreating(DbModelBuilder mB)
{
mB.Entity<User>().HasOptional(x => x.Item).WithOptionalPrincipal(x => x.User).WillCascadeOnDelete(false);
}
但是,我的遷移產生以下內容:
CreateTable(
"dbo.Items",
c => new
{
Id = c.Long(nullable: false, identity: true),
UserId = c.String(),
User_Id = c.String(maxLength: 128),
})
.PrimaryKey(t => t.Id)
.ForeignKey("dbo.Users", t => t.User_Id)
.Index(t => t.User_Id);
我忘記了什麼?
更新:我也嘗試添加[ForeignKey("User")]
到Item.UserId
UPDATE2: 我發現了一個解決辦法,但它不是東西,是很...
OnModelCreating(DbModelBuilder mB)
{
mB.Entity<User>().HasOptional(x => x.Item).WithMany().HasForeignKey(x => x.ItemId);
mB.Entity<Item>().HasOptional(x => x.User).WithMany().HasForeignKey(x => x.UserId);
}
爲什麼你只有虛擬財產? – jannagy02
只是由類圖生成的,稍後會更改 – Nefarion
您是試圖定義一對一還是一對一,還是一對一,還是實際上想要一對一-許多? http://msdn.microsoft.com/en-us/data/jj591620.aspx – Colin