我可以对此进行原型设计,看看会发生什么,但我很懒惰。我希望能够将 EJB3 注入到我的 JPA 实体侦听器中,以便它可以在 PrePersist 操作期间访问 EJB 的功能。那可能吗?如果不是......那么在 JBoss 下,监听器是创建一次,还是每次方法调用创建一次?我想我想了解每次调用在进行 JNDI 查找等方面的轻量级
任何人都知道有关这些主题的良好信息来源,因为我的简短谷歌搜索没有发现任何问题。
您将不得不求助于 JNDI 查找来从您的 EntityListener 访问其他 EJB。我从未见过直接注入它们的方法——我认为这是因为 EntityListener 的语义。
以下内容来自我使用 JBoss 4.0.x 和 4.2.x 的经验。
例如,考虑@PostPersist——在执行插入语句之后调用。有两个问题需要考虑:
如果您打开另一个会话来查询它(即使使用 JNDI 查找),数据库将不会反映当前实体。不能保证事务会因为会话被刷新而被提交。您也不会拥有自动生成的主键。
除了更新托管字段或在提交之前验证数据完整性(与数据库触发器不同)之外,实体侦听器似乎没有任何用途,这严重限制了它们的实用性。具体来说,在 JBoss 中,您甚至无法查找当前的安全上下文来记录谁在进行更改。太糟糕了。
关于存在多少实体侦听器,我在 JBoss 4.2.x 中的经验是只有一个实例存在,并且方法是在容器线程的上下文中调用的。但是,这在集群设置中可能并非如此。无论哪种方式,我都建议您不要在任何实体侦听器中缓存您的引用——尚不清楚 JBoss 究竟会对它们做什么(钝化它们?我希望不会,但你永远不知道!)。
你用的是弹簧吗?如果是这样,您可以使用@Configurable并让该方面为您注入您的依赖项。