有这么一段代码:
public static String getMenuItem(String sWhere,String rWhere,String str) throws SQLException{
String Get = "mname,menuitem";
ResultSet rs = null;
StringBuffer sb = new StringBuffer();
rs = SqlUtilities.getAllResult("rolemenuview", Get, sWhere.concat(rWhere));
if(str.equals("x")){
sb.append(",\"subs\":[");
}
int i = 0;
while(rs.next()&&rs!=null){
if(i==0){
i = 1;
}else{
sb.append(",");
}
sb.append("{\"Title\":\"");
sb.append(rs.getString(1)+"\"");
sb.append(getMenuItem("where pmenu='"+rs.getString(2)+"'", rWhere, str+"x"));
sb.append("}");
}
if(str.equals("x")){
sb.append("]");
}
if(rs!=null&rs.getStatement()!=null){
rs.getStatement().close();
}
return sb.toString();
}
得到的结果
{"Title":"考试科目","subs":[{"Title":"Java"},{"Title":"Javascript"}]},{"Title":"考题管理","subs":[{"Title":"Java内存模型解释"},{"Title":"CSS盒模型解释"}]}
一个标准的json数据,但。。。我完全看不懂执行顺序,先说下查询顺序,第一次查询只有一条数据,根据第一条数据的查询结果,继续查询得到subs里2条数据。
我是在这里看不懂了{"Title":"考试科目","subs":[{"Title":"Java"},{"Title":"Javascript"}]}
}
前面的字符拼接都可以理解,唯独就上面这句最后一个大括号,不知道从哪儿来的,麻烦高手看下
其实后来debug就好了。。。太关注代码本身。。。要警戒啊~~~