背景:我正在编写一个连接到现有 SQL Server DB 的小型桌面应用程序。
我对编写 SQL 查询非常熟悉,但这次我想试一试 JPA。我已经映射了我的实体,一切都很好,但我不太担心性能。
我做了一些分析,结果是 JPA 代码并不比手动映射慢。但是还有一个问题困扰着我。
我已经使用 SQL Server Profiler 记录了查询,并且 Eclipse 链接不断调用 exec sp_prepexec 和 exec sp_unprepare 使用相同的查询但不同的参数。
我重写了代码以在查询中使用参数,但仍然没有运气。
类代码是:
在构造函数中,我创建 EntityManagerFactory 和 EntityManager
emf = Persistence.createEntityManagerFactory("ZapytaniaOKonta_1.0");
em = emf.createEntityManager();
query=prepareQuery();
在 prepareQuery 我使用标准构建器和参数准备查询
CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery<Uczestnik> criteria = builder.createQuery(Uczestnik.class);
Root<Uczestnik> uczestnikRoot = criteria.from(Uczestnik.class);
criteria.select(uczestnikRoot);
ParameterExpression<Boolean> peselFilterParameter = builder.parameter(Boolean.class, "peselFilterParameter");
ParameterExpression<String> peselParameter = builder.parameter(String.class, "peselParameter");
Predicate peselPredicate = orBuilder(builder, uczestnikRoot, peselParameter, peselFilterParameter, Uczestnik_.pesel);
ParameterExpression<Boolean> nipFilterParameter = builder.parameter(Boolean.class, "nipFilterParameter");
ParameterExpression<String> nipParameter = builder.parameter(String.class, "nipParameter");
Predicate nipPredicate = orBuilderNip(builder, uczestnikRoot, nipParameter, nipFilterParameter, Uczestnik_.nip);
ParameterExpression<Boolean> regonFilterParameter = builder.parameter(Boolean.class, "regonFilterParameter");
ParameterExpression<String> regonParameter = builder.parameter(String.class, "regonParameter");
Predicate regonPredicate = orBuilder(builder, uczestnikRoot, regonParameter, regonFilterParameter, Uczestnik_.regon);
criteria.where(builder.and(peselPredicate, nipPredicate, regonPredicate));
uczestnikPeselRegonNipQuery = em.createQuery(criteria);
return uczestnikPeselRegonNipQuery;
使用查询时,我设置了所有参数并调用
query.getResultList();
所以我的问题是如何让 EclipseLink 或其他 JPA2 提供者使用准备好的语句?