My SQL 中怎么递归查询所有的父节点

 我来答
奔跑的窝牛的家
高粉答主

2016-09-06 · 每个回答都超有意思的
知道顶级答主
回答量:3.6万
采纳率:98%
帮助的人:4592万
展开全部
     
//获取表中所有id
protected List<Long> getIdList(String sql, Object ... params) {
    return xxx;
}
 
//获取该menu下的所有子节点
private List<Long> getMenuChildrenIds(long menuId) {
        String sql = "select menu_id from test_tb where p_id = ? ";
        return getIdList(sql, menuId);
}
     
public void getAllChildren(long menuId, List<Long> menuIdList) {
        List<Long> childrenIds = getMenuChildrenIds(menuId);
        for (long menu_Id : childrenIds) {
            menuIdList.add(menu_Id);
        //计数
            int count = geliDao.count("select count(1) from test_tb where p_id = ? ", menu_Id, status);
            if (count > 0) {
                getAllChildren(menu_Id, menuIdList);
            }
        }
}
 
//
public List<Menu> getMenuChildren(long menuId) {
        return orm.list(Menu.class, getMenuChildrenIds(menuId    ).toArray());
    }
 
//执行,全找出来menuIds,放到list里面
List<Long> menuIds = new ArrayList<Long>();
menuIds.add(menu.getMenuId());
getAllChildren(menu.getMenuId(), menuIds);
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式