2016-07-22 82 views
2

我正在試圖插入數據庫。我有以下兩個實體:流利的nHibernate的「非空屬性引用空值或瞬態值」與外鍵

USER:

public class User 
{ 
    private UserDescription _userDescription; 

    public virtual uint Id { get; set; } 
    public virtual string Email { get; set; } 
    public virtual string Username { get; set; } 

    public virtual UserDescription UserDescription 
    { 
     get { return _userDescription; } 
     set { _userDescription = value; } 
    } 

    public virtual void Add(UserDescription userDescription) 
    { 
     if (_userDescription != null) 
     { 
      _userDescription.User = null; 
     } 
     _userDescription = userDescription; 
     _userDescription.User = this; 
    } 

    public class UserMap : ClassMap<User> 
    { 
     public UserMap() 
     { 
      Table("users"); 

      Id(x => x.Id).GeneratedBy.Identity(); 
      Map(x => x.Email).Not.Nullable(); 
      Map(x => x.Username).Not.Nullable(); 

      HasOne(x => x.UserDescription).Cascade.All().LazyLoad(); 
     } 
    } 
} 

而且USERDESCRIPTION

public class UserDescription 
{ 
    public virtual uint Id { get; set; } 
    public virtual User User { get; set; } 
    public virtual uint UserId { get; set; } 
    public virtual string Firstname { get; set; } 
    public virtual string Lastname { get; set; } 

    public class UserDescrptionMap : ClassMap<UserDescription> 
    { 
     public UserDescrptionMap() 
     { 
      Table("usersdescription"); 

      Id(x => x.Id).GeneratedBy.Identity(); 

      Map(x => x.UserId); 
      Map(x => x.Firstname); 
      Map(x => x.Lastname); 

      HasOne(x => x.User).Constrained().ForeignKey(); 
     } 
    } 
} 

我的JSON我通過如下所示:

{ 
    "Email": "[email protected]", 
    "Username": "Something123", 
    "UserDescription": { 
     "Firstname": "John", 
     "Lastname": "Doe" 
    } 
} 

我試圖做一個插入到用戶希望它會級聯下來,並插入到子表UserDescription,但沒有奏效。所以相反,我先插入用戶然後插入UserDescription(不知道這是否是理想的)。

無論如何,我得到以下錯誤,當我嘗試插入UserDescription後,我成功地插入到用戶:

非空屬性引用null或瞬時值Users.Entities.UserDescription.User

有什麼建議嗎?

回答

0

如果有人感興趣,我刪除了UserDescription Mapping中的「.Constrained()」,這似乎工作。雖然我不知道這是否是最好的解決方案!

相關問題