从结果集中填充bean对象

时间:2010-03-06 06:43:16

标签: java stored-procedures jdbc resultset

我遇到了关于从结果集中填充bean对象的问题。

描述:Resultset包含存储过程的结果,该过程是3个表BBOBOV的连接。

我有3张POJO对应于表格。表之间的关系是:B可以有0个或更多BO个,BO可以有0个或更多BOV个。完全在结果集中我有162条记录,其中包含B的重复项。

例如:

B  BO   BOV
1  1     1
1  1     2
1  2     1
2  1     1 

等等。

实际上有10个不同的B。因此,我希望结果集中只有10 B个,而不是162条记录。此外,我应该能够BOBOV获得B=1BO的所有值的相应BOV和{{1}}。

我该怎么做?这是纯Java逻辑,不能为存储过程更改任何内容。只需要处理结果集。

2 个答案:

答案 0 :(得分:2)

这里有一个运行的结果集Map是一个可能的伪代码

[仅限伪代码...无法保证编译]

Map mapofBs = new HashMap();
while(rs.hashNext()) {
    rs.next();
    String bId = rs.getString("columnname for id of b");
    B objectB = mapofBs.get(bId);
    if(objectB == null) {
        objectB = new B();
        //read relevant columns from result set and put into objectB
        mapOfBs.put(bId, objectB)
    }   
    //now onto the boId
    String boId = rs.getString("columnname for id of BO");
    BO objectBO = objectB.getBOForId(boId);
    if(objectBO == null) {
        objectBO = new BO();
        //read relevat columns from result set for objectBO
        objectB.addObjectBO(objectBO);
    }
    String bovID = s.getString("columnname for id of BOV");
    BOV objectBOV = objectBO.getBOVForId(bovId);
    if(objectBOV == null) {
        objectBOV = new BOV();
        //read relevat columns from result set for objectBOV
        objectBO.addObjectBOV(objectBOV);
    }
}
//mapOfBs.keySet() gives you a Set<B> which you are interested in

答案 1 :(得分:0)

更改查询以包含GROUP BY是最佳选择。