我正在使用 FluentNHibernate 尝试使用非常简单的映射(如下)更新一个类。不必选择语言。当我执行插入并设置语言属性时,一切都按预期工作。如果我然后尝试进行更新,仅设置引用属性,则不会发出更新语句。如果我更新其中一个非参考属性和语言,则会发出更新语句。
我正在使用 NH v.3.3.1.4000 和 FluentNH v.1.3.0.733。
public class OrderItem
{
public OrderItem()
{
OrderDate = DateTime.Now;
OrderStatus = Models.OrderStatus.Pending;
}
public virtual int OrderId { get; set; }
public virtual Language Language { get; set; }
public virtual DateTime OrderDate { get; set; }
public virtual OrderStatus OrderStatus { get; set; }
}
public class OrderItemMap : ClassMap<OrderItem>
{
public OrderItemMap()
{
Table("tblOrder");
Id(x => x.OrderId);
Map(x => x.OrderDate);
Map(x => x.OrderStatus).CustomType(typeof(Int32));
References(x => x.Language, "LanguageID").Cascade.None();
}
}
public class LanguageMap : ClassMap<Language>
{
public LanguageMap()
{
Id(x => x.Id);
Map(x => x.Name);
Map(x => x.LanguageCode);
}
}
public class Language
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
public virtual string LanguageCode { get; set; }
}
//更新对象的代码。取消注释代码设置数量会强制更新,但仅设置语言不会。
NHibernateRepository<Language> languagedb = new NHibernateRepository<Language>(SessionFactory);
NHibernateRepository<UserDetail> userdb = new NHibernateRepository<UserDetail>(SessionFactory);
var newItem = itemdb.All().Where(x => x.OrderId == 16).First();
newItem.Language = languagedb.All().Where(x => x.Id == 1).First();
//newItem.Quantity = 200;
itemdb.Update(newItem);