Fluent NHibernate中的DynamicUpdate不起作用



在我的应用程序中,有很多情况下我必须更新数据库中实体的一个属性。在互联网上,我读到DynamicUpdate()应该改变Fluent NHibernate的行为,这样它只会更新属性!=空

所以我写了这样的地图:

public class Building
{
    public virtual Guid Id { get; set; }
    public virtual int ConstructionPhase { get; set; }
    public virtual string Name { get; set; }
    [some other properties]
}
public class BuildingMap : ClassMap<Building>, IMappedEntity
    {
        public BuildingMap()
        {
            DynamicUpdate();
            SelectBeforeUpdate();
            Id(x => x.Id);
            Map(x => x.ConstructionPhase);
            Map(x => x.Name);
            [some other properties]
        }
    }

但是,如果我尝试更新实体并将name属性保留为空,则该名称将在数据库中删除。

我必须以其他方式配置Fluent NHibernate吗?或者有什么问题?

DynamicUpdate()将指示NHibernate只保存已更改的属性,因此加载对象、更改单个属性和刷新会话将只更新已更改的列。

更新:更新单个属性而不去数据库使用hql

var affectedRows = session.CreateQuery("UPDATE MyEntity SET SomeProperty=:newValue WHERE Id=:id")
    .SetParameter("newValue", value)
    .SetParameter("id", id)
    .ExecuteUpdate();

相关内容

  • 没有找到相关文章

最新更新