有这么一段代码:
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"}]}
}
前面的字符拼接都可以理解,唯独就上面这句最后一个大括号,不知道从哪儿来的,麻烦高手看下
2 回答
大话西游666
TA贡献1817条经验 获得超14个赞
递归算法写的有问题,上下文信息太少,不知道怎么回答。
下面的不是一个有效的json字符串,你这个是二段json字符串。
{
"Title": "考试科目",
"subs": [
{
"Title": "Java"
},
{
"Title": "Javascript"
}
]
},
{
"Title": "考题管理",
"subs": [
{
"Title": "Java内存模型解释"
},
{
"Title": "CSS盒模型解释"
}
]
}
有效地应该是:
[
{
"Title": "考试科目",
"subs": [
{
"Title": "Java"
},
{
"Title": "Javascript"
}
]
},
{
"Title": "考题管理",
"subs": [
{
"Title": "Java内存模型解释"
},
{
"Title": "CSS盒模型解释"
}
]
}
]
添加回答
举报
0/150
提交
取消
