EntityManager变为null

时间:2015-05-14 08:30:32

标签: java hibernate jpa persistence

使用EntityManager时出现了一个奇怪的错误。这是代码的摘录。

@PersistenceUnit
EntityManagerFactory factory;
@Resource
UserTransaction transaction;
EntityManager em;

方法内部:

try{
datos.crearDatos(docEntrada);
ctx.setDatosMensajes(datos);
factory=Persistence.createEntityManagerFactory("ealia");
transaction = (UserTransaction)new InitialContext().lookup("java:comp/UserTransaction");
EntityManager em = factory.createEntityManager();

//Do whatever it does, everything works fine.
// HERE THE ENTITY MANAGER IS NOT NULL
}
catch (Exception e){

}
finally{
    // HERE THE ENTITY MANAGER IS NULL 
        try {
            SVCSMensajes.grabarMensajeSalida(datos, Constantes.MENSAJE_SALIDA_WS_USUARIOS_GESTION, Constantes.NOMBRE_SERVICIO_WS_USUARIOS_GESTION, Constantes.MENSAJE_ENTRADA_WS_USUARIOS_GESTION, em, ctx,transaction);
        } catch (CecaException e) {
            // No devolvemos error en este caso
        }

        em.close();
        factory.close();
  }

我不明白为什么eentity manager在finally中变为null,当try的末尾不为null时,当一切正常时,没有例外。我跟踪变量,它变为null,中间没有中间指令。

相反,如果我以这种方式重新排列代码

    factory=Persistence.createEntityManagerFactory("ealia");
    transaction = (UserTransaction)new  InitialContext().lookup("java:comp/UserTransaction");
    EntityManager em = factory.createEntityManager();

    try{
        datos.crearDatos(docEntrada);
        ctx.setDatosMensajes(datos);
    ....
    }
    ....
一切正常。有人可以解释一下吗?

1 个答案:

答案 0 :(得分:0)

您将em声明为此try块的局部变量:

EntityManager em = factory.createEntityManager();

该变量对finally块不可见。该块使用您声明为类的字段的那个。

您需要将上述行更改为:

em = factory.createEntityManager();

为了初始化你的字段,而不是局部变量。

更好的是,您可能需要注入EntityManager而不是手动创建它。

相关问题