1

我正在使用Jodd DbOom来管理我的查询,它真的很棒。但现在我正面临一个无证的情况。

我有一个返回对象列表(A)的查询,每个 A 都有一个对象列表(B),每个 B 都与其他对象(C、D、E 等)连接。问题是该类JoinHintResolver没有在 B 对象上设置值 C、D、E。B 对象在 A 对象上正确设置。

以下是重现错误的测试方法。其他使用的类(Girl, BadBoy)来自 Jodd 测试包。

public void testHintsList() {
    Room room = new Room();
    Girl girl = new Girl();
    BadBoy badBoy = new BadBoy();
    Object[] data = new Object[] { room, badBoy, girl };

    JoinHintResolver jhr = new JoinHintResolver();
    Object[] result = jhr.join(data, "room, room.boys, room.boys.girl");
    assertEquals(1, result.length);
    assertTrue(result[0] instanceof Room);
    room = (Room) result[0];
    badBoy = room.getBoys().get(0);
    assertEquals(girl, badBoy.girl);
}

public class Room {
    private Long id;
    private List<BadBoy> boys;

    public Room() {
    }

    public Long getId() {
    return id;
    }

    public void setId(Long id) {
    this.id = id;
    }

    public List<BadBoy> getBoys() {
    return boys;
    }

    public void setBoys(List<BadBoy> boys) {
    this.boys = boys;
    }
}

文档没有这样的例子,谷歌也没有。所以我不知道是我做错了什么,还是乔德没有为这种情况做好准备。

我如何设置提示以便 Jodd 正确设置值?

4

1 回答 1

0

所以这里的问题是BadBoy你的Room. 和提示:

room.boys.girl

建议他们将Girl实例注入到集合中。用java的话来说,这相当于:

getRoom().getBoys().setGirl(girl);

显然,由于getBoys()返回 a List,我们不能设置girl属性。

要测试我所说的,请改用以下提示:

room.boys[0].girl

这会将girl实例注入到列表的第一个元素中。或者,您可以将您的更改Room为只有一个Boy属性,而不是列表,原始提示将起作用。

我希望这对你有用:)

(见测试

编辑

这个分支中,我有一些看起来像修复的东西 :) 现在你可以编写如下内容:

select $C{room.*}, $C{room.boys:boy.*}, $C{room.boys.girl:girl.*}
    from $T{Room room} join $T{Boy4 boy} on $room.id=$boy.roomId 
    join $T{Girl4 girl} on $boy.id=$girl.boyId 
    order by $room.id, $boy.id

你可以有以下模型:

Room有清单Boy。每个Boy人都有一个Girl分配。什么时候entityAware打开,这应该工作。也许你有时间测试分支?

于 2015-09-20T19:32:58.527 回答