在我的应用程序中,有很多情况下我必须更新数据库中实体的一个属性。在互联网上,我读到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();