使用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);
....
}
....
一切正常。有人可以解释一下吗?
答案 0 :(得分:0)
您将em
声明为此try
块的局部变量:
EntityManager em = factory.createEntityManager();
该变量对finally
块不可见。该块使用您声明为类的字段的那个。
您需要将上述行更改为:
em = factory.createEntityManager();
为了初始化你的字段,而不是局部变量。
更好的是,您可能需要注入EntityManager
而不是手动创建它。