0

我正在使用 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);
4

2 回答 2

1

尝试Cascade.SaveUpdate()在您的Language参考上使用,而不是Cascade.None().

在Ayende 的帖子或官方 NHibernate文档中阅读有关级联选项的更多信息。

于 2012-07-22T22:08:03.993 回答
0

您是否对两个存储库使用了相同的会话?您是否在会话中使用了事务?如果是这样,尝试做session.Commit()或至少做session.Flush()。更多细节在这里

于 2012-07-23T02:38:59.153 回答