4

假设我必须触发这样的查询:

Select primarykey, columnname, old_value, new_value from first_audit_log;

Select primarykey, columnname, old_value, new_value from second_audit_log;

Select primarykey, columnname, old_value, new_value from third_audit_log; ...so on

audit_log没有作为 JPA 实体映射到任何类,我严格不能nn.*_audit_logs

使用本机查询功能,我如何才能最好地将其映射到泛型类?尝试选择新功能,但不确定...因此,感谢您的帮助。

4

2 回答 2

3

由于您的审计日志表共享相同的列,您可以创建一个“统一”这些表的视图并将单个 Java 类映射到该视图。我相信你可以,因为你不需要写更新,我猜。

作为替代方案,使用本机查询将是一个不错的选择。

编辑

1) 如果您的审计日志已经是视图,您可以基于其他视图创建一个视图,如果您不想为每个视图创建一个映射 Java 类。只要记住添加一个具有值的虚拟列,1如果该行来自“第一个”审计日志,2如果它来自第二个审计日志,依此类推,这样您就可以将它们分开。

2)为了使用本机查询,假设您的持久性提供程序是 Hibernate,您可以在此示例中执行以下操作:

EntityManagerFactory emf = Persistence.createEntityManagerFactory("test");
EntityManager em = emf.createEntityManager();

Session sess = em.unwrap(Session.class); // <-- Use Hibernate-specific features
SQLQuery query = sess.createSQLQuery(
   "SELECT AVG(age) AS averageAge, AVG(salary) as averageSalary FROM persons");

query.setResultTransformer(Transformers.aliasToBean(MyResult.class));
MyResult result = (MyResult) query.list().get(0);

whereMyResult声明如下:

public class MyResult {

    private BigDecimal averageAge;
    private BigDecimal averageSalary;

    public BigDecimal getAverageAge() {
        return averageAge;
    }
    public void setAverageAge(BigDecimal averageAge) {
        this.averageAge = averageAge;
    }
    public BigDecimal getAverageSalary() {
        return averageSalary;
    }
    public void setAverageSalary(BigDecimal averageSalary) {
        this.averageSalary = averageSalary;
    }

}

persons表是这样的(MySQL语法):

CREATE TABLE `persons` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `firstname` varchar(255) NOT NULL,
  `lastname` varchar(255) NOT NULL,
  `age` int(11) NOT NULL,
  `salary` int(11) NOT NULL,
  PRIMARY KEY (`id`)
);

您可以轻松地根据您的需要调整此示例,只需将其替换personsMyResult您想要的即可。

于 2013-03-05T17:02:32.167 回答
1

sql 查询中的别名会自动转换为大写,并且它会以大写查找 setter,结果会抛出 org.hibernate.PropertyNotFoundException 异常。任何建议将不胜感激。

例如,下面的语句正在寻找 setter ID 而不是 Id/id(Could not find setter for ID on class Data)

List<Data> result = entityManager.unwrap(Session.class) 
            .createSQLQuery("Select id as id from table") 
            .setParameter("day", date.getDayOfMonth()) 
            .setParameter("month", date.getMonthOfYear()) 
            .setParameter("year", date.getYear()) 
           .setResultTransformer(Transformers.aliasToBean(Data.class))
           .list();

class Data {
  Integer id;

  public Integer getId() {
    return id;
  }

  public void setId(Integer id) {
   this.id = id;
  }
}
于 2015-11-24T02:24:56.453 回答