我遇到了关于从结果集中填充bean对象的问题。
描述:Resultset包含存储过程的结果,该过程是3个表B
,BO
和BOV
的连接。
我有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条记录。此外,我应该能够BO
和BOV
获得B=1
和BO
的所有值的相应BOV
和{{1}}。
我该怎么做?这是纯Java逻辑,不能为存储过程更改任何内容。只需要处理结果集。
答案 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是最佳选择。