JOOQ:在逻辑上对来自公共界面中不同表的列进行分组

时间:2018-09-26 19:16:17

标签: java sql jooq

我们有一个表设计,其中许多表共享一些列,例如在一种情况下,我们的某些表具有列markedForDeletion。在另一种情况下,我们的多个表具有列approvedAtapprovedBy。这些表不共享任何要成为JOINED数据的内容,因此,我不想为这些表引入一个通用的JOIN表(由于性能问题,这也不是一种选择)。

但是从应用程序的角度来看,我确实有非常相似的任务要执行。例如,如果我创建一个新行,则在哪个表中插入条目都没关系,我需要从请求中提取批准者和请求时间,以将其与其他行一起填充到我的表中数据稍后在我的代码中。

在JOOQ中,我现在可以做类似的事情

private void insertApprovalInformation(Record record, RequestContext ctx) {
   record.set(DSL.field("approver"), ctx.getRequestUser());
   record.set(DSL.field("approvedAt"), ctx.getRequestTime());
}

但是,我将用这种方法来释放所有我钟爱的类型安全性。 理想情况下,我想写类似

private void insertApprovalInformation(Approvablerecord record, RequestContext ctx) {
   record.set(ApprovableTable.APPROVER, ctx.getRequestUser());
   record.set(ApprovableTable.APPROVED_AT, ctx.getRequestTime());
}

我知道这类似于Postgres继承功能,但是我想使这个数据库更独立,并希望在Oracle数据库中使用它。我想像配置JOOQ生成器,然后告诉它“这四个表属于一个逻辑组,我将其命名为“ approvable”,并且它们都具有列APPROVERAPPROVED_AT。”这将使JOOQ生成类,例如为该组实现标记接口。

我认为这在考虑历史化,批准等常见任务,标记要删除的行等时可能是一个相当常用的功能。

我的问题:

  • JOOQ中是否已经有一种方法可以实现我希望的类型安全结果?
  • 关于如何以一种类型安全的方式处理此场景的其他建议?
  • 还是我应该忘记这里的类型安全性?

1 个答案:

答案 0 :(得分:0)

您可以轻松地配置和扩展jOOQ代码生成器以为您添加类型信息。由于您要处理生成的记录,因此只需在代码库中添加这样的新接口即可:

public interface Approvable {
    void setApprover(String approver);
    void setApprovedAt(Timestamp approvedAt);
}

然后配置代码生成器,以使用生成器策略让所有相关的生成记录实现上述接口:

一个配置示例:

..
<generator>
  <strategy>
    <matchers>
      <tables>
        <table>
          <expression>MY_TABLE</expression>
          <recordImplements>com.example.Approvable</recordImplements>
        </table>
      </tables>
    </matchers>
  </strategy>
</generator>