JOOQ - 将结果转换为Pojo

时间:2014-09-23 14:49:51

标签: java sql jooq

我看到当我们使用.selectFrom(TABLE).fetchInto(POJO.class);时,JOOQ会自动返回POJO

但是可以将复杂查询的结果转换为多个POJO吗?

示例:

此查询将所有列的数组返回到表Support和Box中。可以将它们转换为Support和Box Pojo吗?

Result<Record> results = query.select()
                         .from(BOX)
                         .join(SUPPORT)
                         .on(SUPPORT.ID.equal(BOX.SUPPORT_ID))
                         .where(SUPPORT.ID.equal("XXXX"))
                         .orderBy(BOX.ID)
                         .fetch();

我测试了方法.intoGroups(SUPPORT.ID, Box.class),它运行正常。但我没有支持对象。

2 个答案:

答案 0 :(得分:5)

实例化为SelectSeekStep1

使用aliases会更方便:

Box b = BOX.as("b");
Support s = SUPPORT.as("s");

SelectSeekStep1<Integer, Integer> sql = query.select(b.ID, s.ID /* other columns */)
     .from(b)
     .join(s)
        .on(s.ID.eq(b.SUPPORT_ID))
     .where(s.ID.eq("XXXX"))
     .orderBy(b.ID)
;

然后只需获取您需要的内容:

List<BoxRecord> boxes = sql.fetchInto(BOX); 
SupportRecord support = sql.limit(1).fetchOneInto(SUPPORT);

答案 1 :(得分:2)

对于未来的读者,如果要使用插入方法实现相同的行为,则应使用:

insertInto(BOX)
    .set(BOX.COLUMN1, UInteger.valueOf(1))
    .set(BOX.COLUMN2, "test")
    .returning()
    .fetchOne()
    .into(<POJO_class>.class);