首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在Nhibernate中使用自定义sql语句删除行

在Nhibernate中使用自定义sql语句删除行
EN

Stack Overflow用户
提问于 2009-05-27 17:06:40
回答 4查看 1.6K关注 0票数 2

我正在使用NHibernate,并且有一个要求,当我删除一行时,我不应该硬删除该行,而是将状态更新为delted,并设置一些系统属性,比如谁删除了等等。

为此,我决定使用自定义sql语句,如下所示。

代码语言:javascript
运行
复制
<sql-delete>
  update PPDE set SysStatusID = 2 where PPDID =? 
</sql-delete>

在sql语句中,我只能获得对id的引用,但是我如何才能将SysUserID更新为删除此行的用户。

主要介绍如何在自定义sql语句中设置动态参数值。

任何帮助都是非常感谢的。

EN

回答 4

Stack Overflow用户

发布于 2009-05-27 19:32:55

一种方法是实现DeleteEvent-listener,它在nhibernate决定删除实体时触发。从那里,根据一些逻辑(通常是在实体上查找接口),您可以决定是硬删除还是软删除实体。如果您软删除它,您可以更新属性,如"IsDeleted“、"DeletedAt”、"DeletedBy“等。

可以在以下网址找到详细描述上述内容的博客文章:The NHibernate FAQ - Soft Deletes

票数 2
EN

Stack Overflow用户

发布于 2009-05-27 17:19:54

你能使用interceptor做到这一点吗

代码语言:javascript
运行
复制
    public void OnDelete(object entity,
                         object id,
                         object[] state,
                         string[] propertyNames,
                         IType[] types)
    {
        // if entity is myentity 
        // update user property
    }
票数 0
EN

Stack Overflow用户

发布于 2009-05-27 17:30:50

Hibernate将尝试自动将“?”替换为实体中的值。当您调用session.Delete(entity)时,它将使用映射到PPDID列的属性的值。

话虽如此,我认为在这种情况下使用自定义sql语句不是一个好主意。我认为你的代码很难理解和维护。当某人看到session.Delete(entity)时,他会期望执行一条DELETE语句,但实际上它会得到一条UPDATE语句。我会坚持使用之前设置了正确值的session.Update(entity)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/916943

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档