目前,我有一个场景,我想为执行的查询添加事件监听器。我的实体监听器public class EntityListener implements PostInsertEventListener, PostUpdateEventListener, PostDeleteEventListener {我的仓库@Transactional@Modifying@Query(value = "UPDATE example e SET e.name = :name WHERE e.id = :id", nativeQuery = true) void testUpdatedQuery(@Param("name") String name, @Param("id") String id);如果我使用 spring-data-jpa 的方法,事件侦听器工作正常,但如果我尝试上面的本机查询,我将无法触发事件。所以,我的问题是如何收听“本机查询”事件?
1 回答
繁花如伊
TA贡献2012条经验 获得超12个赞
所以,我的问题是如何收听“本机查询”事件?
您至少不能以类似于 EntityListener 的方式进行。这样做的原因是无法确定给定更新的受影响实体。
我看到以下选项:
实现使用相同 where 子句加载受影响实体的自定义方法,然后触发某种事件机制。
正如 Zorglube 建议的那样,您还可以使用数据源代理来拦截每个 SQL 查询,但这对于您的用例来说可能是低级别的,因为您会看到大量您可能不关心的语句,因为它们是由您创建的JPA 实施。
添加回答
举报
0/150
提交
取消