java实现遍历树形菜单方法——Dao层

简介: java实现遍历树形菜单方法——Dao层

Dao层接口:


/**  
* @Title: IVoteTreeDao.java
* @Package org.dao
* @Description: TODO该方法的主要作用:
* @author A18ccms A18ccms_gmail_com  
* @date 2017-5-6 下午10:38:47
* @version V1.0  
*/
package org.dao;
import java.util.List;
import org.entity.VoteTree;
 /**   
 *    
 * 项目名称:testTree   
 * 类名称:IVoteTreeDao   
 * 类描述:   
 * 创建人:Mu Xiongxiong  
 * 创建时间:2017-5-6 下午10:38:47   
 * 修改人:Mu Xiongxiong   
 * 修改时间:2017-5-6 下午10:38:47   
 * 修改备注:   
 * @version    
 *    
 */
public interface IVoteTreeDao {
  //查询最小的level
  Long minId();
  
  //根据最小的查询所有一级菜单
  List<VoteTree> getFirstLevel(Long minLevel);
  
  //根据pid查询所有相对应的子集
  List<VoteTree> getNextSubSet(VoteTree tvote);
  
  //递归查询
  List<VoteTree> getDeeptLevel(VoteTree tvote);
  
  
}


HibernateBaseDao实现:


/**  
* @Title: BaseHibernateDao.java
* @Package org.dao
* @Description: TODO该方法的主要作用:
* @author A18ccms A18ccms_gmail_com  
* @date 2017-5-6 下午1:50:18
* @version V1.0  
*/
package org.dao;
import org.hibernate.Session;
import org.util.HibernateUtil;
 /**   
 *    
 * 项目名称:votedemo   
 * 类名称:BaseHibernateDao   
 * 类描述:   hibernate的工具类BaseDao
 * 创建人:Mu Xiongxiong  
 * 创建时间:2017-5-6 下午1:50:18   
 * 修改人:Mu Xiongxiong   
 * 修改时间:2017-5-6 下午1:50:18   
 * 修改备注:   
 * @version    
 *    
 */
public class BaseHibernateDao {
  
  
  /**
   * 
  * @Title: getSession
  * @Description: 该方法的主要作用:打开session 
  * @param  @return 设定文件  
  * @return  返回类型:Session   
  * @throws
   */
  public Session getSession(){
    return HibernateUtil.getSession();
  }
  
  /**
   * 
  * @Title: closeSession
  * @Description: 该方法的主要作用:关闭session 
  * @param   设定文件  
  * @return  返回类型:void   
  * @throws
   */
  public void closeSession (){
    HibernateUtil.closeSession();
  }
  
}


Dao层实现类:

/**  
* @Title: IVoteTreeDaoImpl.java
* @Package org.dao.impl
* @Description: TODO该方法的主要作用:
* @author A18ccms A18ccms_gmail_com  
* @date 2017-5-6 下午10:40:25
* @version V1.0  
*/
package org.dao.impl;
import java.util.ArrayList;
import java.util.List;
import javax.persistence.criteria.From;
import org.dao.BaseHibernateDao;
import org.dao.IVoteTreeDao;
import org.entity.VoteTree;
 /**   
 *    
 * 项目名称:testTree   
 * 类名称:IVoteTreeDaoImpl   
 * 类描述:   
 * 创建人:Mu Xiongxiong  
 * 创建时间:2017-5-6 下午10:40:25   
 * 修改人:Mu Xiongxiong   
 * 修改时间:2017-5-6 下午10:40:25   
 * 修改备注:   
 * @version    
 *    
 */
public class IVoteTreeDaoImpl extends BaseHibernateDao implements IVoteTreeDao {
  //
  
  //查询最小的数
  @Override
  public Long minId() {
    String hql = "select min(levels) from VoteTree";
    Long minCount = (Long) getSession().createQuery(hql).uniqueResult(); 
    System.out.println("最小的数是:"+minCount);
    return minCount;
  }
  //查询一级菜单
  @Override
  public List<VoteTree> getFirstLevel(Long minLevel) {
    String hql="from VoteTree where levels=?";
    List<VoteTree> listFirstLevel = getSession().createQuery(hql)
                          .setParameter(0, minLevel)
                          .list();
    return listFirstLevel;
  }
  //根据一级id查询所有的子集
  @Override
  public List<VoteTree> getNextSubSet(VoteTree tvote) {
    String hql = "from VoteTree where pid = ?";
    List<VoteTree> tNextLevel = getSession().createQuery(hql).setParameter(0, tvote.getId()).list();
    
    //遍历这个二级目录的集合
    for (VoteTree voteTree : tNextLevel) {
      List<VoteTree> ts = getDeeptLevel(voteTree);
      //将下面的子集都依次递归进来
      voteTree.setChildren(ts);
    }
    return tNextLevel;
  }
  //递归查询
  @Override 
  public List<VoteTree> getDeeptLevel(VoteTree tvote) {
    String hql="from VoteTree where pid = ?";
    List<VoteTree> tsLevel = getSession().createQuery(hql).setParameter(0, tvote.getId()).list();
    if(tsLevel.size()>0){
      for (int i = 0; i <tsLevel.size(); i++) {
        getDeeptLevel(tsLevel.get(i));
      }
    }
    return tsLevel;
  }
}




相关文章
|
1月前
|
算法 Java 开发者
Java 项目实战数字华容道与石头迷阵游戏开发详解及实战方法
本文介绍了使用Java实现数字华容道和石头迷阵游戏的技术方案与应用实例,涵盖GUI界面设计、二维数组操作、游戏逻辑控制及自动解法算法(如A*),适合Java开发者学习游戏开发技巧。
180 46
|
2月前
|
安全 Java API
Java 集合高级应用与实战技巧之高效运用方法及实战案例解析
本课程深入讲解Java集合的高级应用与实战技巧,涵盖Stream API、并行处理、Optional类、现代化Map操作、不可变集合、异步处理及高级排序等核心内容,结合丰富示例,助你掌握Java集合的高效运用,提升代码质量与开发效率。
182 0
|
2月前
|
算法 搜索推荐 Java
Java中的Collections.shuffle()方法及示例
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,支持原地修改。可选传入自定义 `Random` 对象以实现结果可重复,适用于抽奖、游戏、随机抽样等场景。
87 0
|
2月前
|
安全 Java
JAVA:Collections类的shuffle()方法
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的工具方法,适用于洗牌、抽奖等场景。该方法直接修改原列表,支持自定义随机数生成器以实现可重现的打乱顺序。使用时需注意其原地修改特性及非线程安全性。
92 0
|
2月前
|
算法 安全 Java
java中Collections.shuffle方法的功能说明
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,常用于洗牌、抽奖等场景。可选 `Random` 参数支持固定种子以实现可重复的随机顺序。方法直接修改原列表,无返回值。
90 0
|
Java
JAVA方法的定义
JAVA方法的定义
180 0
|
6月前
|
存储 JSON Java
《从头开始学java,一天一个知识点》之:方法定义与参数传递机制
**你是否也经历过这些崩溃瞬间?** - 看了三天教程,连`i++`和`++i`的区别都说不清 - 面试时被追问&quot;`a==b`和`equals()`的区别&quot;,大脑突然空白 - 写出的代码总是莫名报NPE,却不知道问题出在哪个运算符 🚀 这个系列就是为你打造的Java「速效救心丸」!我们承诺:每天1分钟,地铁通勤、午休间隙即可完成学习;直击痛点,只讲高频考点和实际开发中的「坑位」;拒绝臃肿,没有冗长概念堆砌,每篇都有可运行的代码标本。上篇:《输入与输出:Scanner与System类》 | 下篇剧透:《方法重载与可变参数》。
129 25
|
安全 Java 编译器
杭州 【Java基础知识 11】java泛型方法的定义和使用(学习+改进+自己理解,想法) (借鉴-侵-删)
杭州 【Java基础知识 11】java泛型方法的定义和使用(学习+改进+自己理解,想法) (借鉴-侵-删)
107 1
|
存储 Java
Java数组与带参数方法:定义、调用及实践
Java数组与带参数方法:定义、调用及实践
163 1
|
存储 Java
Java中带返回值方法的定义与调用技术
Java中带返回值方法的定义与调用技术
222 1

热门文章

最新文章