【发布时间】:2012-09-17 16:59:53
【问题描述】:
我正在使用带有内置 OpenJPA 1.2.3 和 Oracle 数据库的 Websphere Application Server 7。我有以下实体:
@NamedNativeQuery(name=Contract.GIVE_ALL_CONTRACTS,
query="SELECT number, name \n" +
"FROM contracts \n" +
"WHERE startdate <= ?1 \n" +
"AND enddate > ?1",
resultSetMapping = Contract.GIVE_ALL_CONTRACTS_MAPPING)
@SqlResultSetMapping(name = Contract.GIVE_ALL_CONTRACTS_MAPPING,
entities = { @EntityResult(entityClass = Contract.class, fields = {
@FieldResult(name = "number", column = "number"),
@FieldResult(name = "name", column = "name")
})
})
@Entity
public class Contract {
public static final String GIVE_ALL_CONTRACTS = "Contract.giveAllContracts";
public static final String GIVE_ALL_CONTRACTS_MAPPING = "Contract.giveAllContractsMapping";
@Id
private Integer number;
private String name;
public Integer getNumber() {
return number;
}
public String getName() {
return name;
}
}
以下代码用于检索合同:
Query query = entityManager.createNamedQuery(Contract.GIVE_ALL_CONTRACTS);
query.setParameter(1, referenceDate);
List contracts = query.getResultList();
entityManager.clear();
return contracts;
检索到的合同被传递给网络服务。
对于 3608 条记录,在 Oracle 开发人员中执行此查询大约需要 0.35 秒。 对 query.getResultList() 的调用大约需要 4 秒。
在实体的构造函数中使用记录器,它记录大约有 10-20 个使用相同时间戳创建的实体。然后 0,015 秒它做了别的事情。我猜是 OpenJPA 的东西。
有没有办法加快 OpenJPA?或者是唯一的解决方案缓存?
【问题讨论】:
-
我建议你使用 profiler。