我正在使用NHibernate,并且有一个要求,当我删除一行时,我不应该硬删除该行,而是将状态更新为delted,并设置一些系统属性,比如谁删除了等等。
为此,我决定使用自定义sql语句,如下所示。
<sql-delete>
update PPDE set SysStatusID = 2 where PPDID =?
</sql-delete>在sql语句中,我只能获得对id的引用,但是我如何才能将SysUserID更新为删除此行的用户。
主要介绍如何在自定义sql语句中设置动态参数值。
任何帮助都是非常感谢的。
发布于 2009-05-27 19:32:55
一种方法是实现DeleteEvent-listener,它在nhibernate决定删除实体时触发。从那里,根据一些逻辑(通常是在实体上查找接口),您可以决定是硬删除还是软删除实体。如果您软删除它,您可以更新属性,如"IsDeleted“、"DeletedAt”、"DeletedBy“等。
可以在以下网址找到详细描述上述内容的博客文章:The NHibernate FAQ - Soft Deletes
发布于 2009-05-27 17:19:54
你能使用interceptor做到这一点吗
public void OnDelete(object entity,
object id,
object[] state,
string[] propertyNames,
IType[] types)
{
// if entity is myentity
// update user property
}发布于 2009-05-27 17:30:50
Hibernate将尝试自动将“?”替换为实体中的值。当您调用session.Delete(entity)时,它将使用映射到PPDID列的属性的值。
话虽如此,我认为在这种情况下使用自定义sql语句不是一个好主意。我认为你的代码很难理解和维护。当某人看到session.Delete(entity)时,他会期望执行一条DELETE语句,但实际上它会得到一条UPDATE语句。我会坚持使用之前设置了正确值的session.Update(entity)。
https://stackoverflow.com/questions/916943
复制相似问题