gpt4 book ai didi

java结果集中嵌套while循环

转载 作者:太空宇宙 更新时间:2023-11-04 06:59:54 25 4
gpt4 key购买 nike

我想合并 2 个 resultSet 的结果,这些结果是从 sql 查询返回的结果。实现这一目标的最佳方法是什么?

我的计划是遍历 2 个结果集,从两个结果集中打印出最终结果。两个结果集都有相同的 id 列,即它们的第一列。但对于内部 while 循环,我只打印出第一个值。

我认为当存在匹配时,它会打印第二个结果集中的值,并跳出循环。然后当有另一个匹配时,它会再次打印出该值。

while (set1.next())
{
System.out.print("Id: "+set1.getInt(1)+", Name: "+set1.getString(2));

while (set2.next())
{
if (set1.getInt(1)==(set2.getInt(1)))
{
System.out.print(", Alias: "+set2.getString(2);
break;
}
}

System.out.println();
}

编辑:

ResultSet set1: 
id | name
1 | A
2 | B
3 | C
...

ResultSet set2:
id | alias
1 | F
2 | G
2 | H

我要打印:

Id: 1, Name: A, Alias: F
Id: 2, Name: B, Alias: G, H

仅供引用,两组中的 id 均按升序排列

最佳答案

下面的循环只会为外循环执行一次

        while (set2.next()){
if (set1.getInt(1)==(set2.getInt(1))){
System.out.print(", Alias: "+set2.getString(2);
break;
}
}

每次执行外循环时,您都需要重新初始化迭代器。

关于java结果集中嵌套while循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22239423/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com