HashMap> results = new HashMap>();
//输入的ID
int ID=Integer.parseInt(Catid);
//表中所有的数据
aas=cloudnewscategory.selectAllGory();
System.out.println("所有记录="+aas);
for (CloudNewsCategory gory : aas) {
System.out.println("536456747="+results.get(gory.getPARENTID()));
List<CloudNewsCategory> beans = results.get(gory.getPARENTID());
if (beans == null) {
beans = new ArrayList<CloudNewsCategory>();
results.put(gory.getPARENTID(), beans);
}
beans.add(gory);
}
displayMap(results,ID,"");
public static void displayMap(HashMap<Integer, List<CloudNewsCategory>> results,
int startKey, String str) {
List<CloudNewsCategory> list = results.get(startKey);
// System.out.println("shuji="+results.get(startKey));
for (CloudNewsCategory gory : list) {
vv.add(gory.getID());
System.out.println(str + gory.getID() + "|"+gory.getCATEGORY());
if (results.containsKey(gory.getID())) {
displayMap(results, gory.getID(), str + " ");
}
}
}
怎么得到一个list 里面是所有的子ID阿 急求
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
你这样肯定不好,推荐你用Map<父ID,子ID的List>,你这样去做,父ID就记录了,也能按照相应的记录去取,另外,你要先把对应的子ID整合成List.
尽量不要用递归,数据量大的时候,会有问题。