我正在寻找一种以编程方式验证JPA查询的方法.
@H_403_2@在(Spring)事务中,我有一个要运行的查询列表.这些查询可能包含我想要捕获的语法错误,以便事务可以继续.
@H_403_2@我的第一个想法是使用EntityManager并创建并执行我的查询,如果它们失败,那么我可以简单地捕获异常,记录警告并继续.
@H_403_2@问题是,当出现问题时,事务被标记为rollbackOnly,因此我的当前事务被回滚,这不是我想要的.
@H_403_2@在伪代码中,它或多或少像这样:
EntityManager em = ...; em.getTransaction().begin(); List<String> queries = Arrays.asList("select e from Department d","select d from Department d"); for(String query:queries) { TypedQuery<Department> typedQuery = em.createQuery(query,Department.class); // This can throw an exception List<Department> deps = typedQuery.getResultList(); // This can also throw an exception //... do some stuff with the departements }@H_403_2@到目前为止,我发现的替代方法是从原始的创建另一个EntityManager(em.getEntityManagerFactory().createEntityManager()),首先运行我的查询,然后在原始的中重新执行它们(如果成功),但这真的不高效,看起来很难看. @H_403_2@我使用EclipseLink作为JPA实现,我无法切换到另一个JPA实现.