欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java如何實現(xiàn)樹形查詢

 更新時間:2024年07月17日 09:31:09   作者:安達(dá)魯狗  
這篇文章主要介紹了java實現(xiàn)樹形查詢方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

java實現(xiàn)樹形查詢

首先這個樹形查詢,你肯定不能用他內(nèi)置sql語句吧

這里我自己在dao層寫一句sql語句進(jìn)行查詢

@Query(value = "select * from TB_UIM_MENU_TEST t START WITH t.PID IS NULL" +
        " CONNECT BY PRIOR t.ID = t.PID order by t.PID NULLS first,t.MENU_SORT ASC",nativeQuery = true)
List<MenuTestDTO> findTree();

這里我寫的原生sql語句,不原生的俺也不會。

接下來就要實現(xiàn)樹形查詢了

service層代碼我就不po出來了,直接po實現(xiàn)層的代碼:

public List findTree() {
    List<MenuTreeVO> list = new ArrayList<>();
    List<MenuTestDTO> dataList = menuTestDAO.findTree();
    List<MenuTreeVO> resultList = new ArrayList<>();
    for (int i = 0; i < dataList.size(); i++) {
        MenuTestDTO menuTestDTO = dataList.get(i);
        MenuTreeVO menuTreeVO = new MenuTreeVO();
        menuTreeVO.setId(menuTestDTO.getId());
        menuTreeVO.setPid(menuTestDTO.getPid());
        menuTreeVO.setLockState(menuTestDTO.getLockState());
        menuTreeVO.setLogo(menuTestDTO.getLogo());
        menuTreeVO.setMenuSort(menuTestDTO.getMenuSort());
        menuTreeVO.setName(menuTestDTO.getName());
        menuTreeVO.setRoute(menuTestDTO.getMenuRoute());
        resultList.add(menuTreeVO);
    }
    for (int i = 0; i < resultList.size(); i++) {
        MenuTreeVO menuTreeVO = resultList.get(i);
        if (menuTreeVO.getPid() == null){
            //一級節(jié)點(diǎn)
            list.add(menuTreeVO);
        }else {
            //子節(jié)點(diǎn)
            findFather(menuTreeVO,list);
        }
    }
    return list;
}

到這里有人就要問了,你怎么知道不同子級對應(yīng)的父級是哪個啊,問得好!

在上述方法中有一個方法是findFather()這個就是進(jìn)行父級尋找的方法,數(shù)據(jù)庫里肯定是有關(guān)系的,

下面看看這個findFather()方法

private List findFather(MenuTreeVO private List findFather(MenuTreeVO menuTreeVO,List list){
    for (int i = 0; i < list.size(); i++) {
        MenuTreeVO menuvo = list.get(i);
        //判斷是否為對應(yīng)節(jié)點(diǎn)的子節(jié)點(diǎn)
        if (menuvo.getId().equals(menuTreeVO.getPid())){
            menuvo.getChildren().add(menuTreeVO);
        }
    }
    return null;
}

像我這里表中是有PID和ID的區(qū)別,

子級的PID和父級的ID是一樣的,而父級的PID是空的,所以第一個判斷使用ID進(jìn)行判斷,

如果ID為空那就是父級,把他取出來存在一個List當(dāng)中,你得先聲明空的集合奧,類似于漢諾塔那樣。

然后通過ID和PID的關(guān)系再去找子級,需要說的一點(diǎn)是,

我這里用的是域?qū)ο筠D(zhuǎn)換,自己封裝了一下,這個VO中有這么一個元素:

private List<MenuTreeVO> children = new ArrayList<>();

我只能說DDDD,這就是用來存子級的list對象。

大概差不多就是這個意思,自己理解一下就行。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java的Guava工具包介紹

    java的Guava工具包介紹

    Java開發(fā)的同學(xué)應(yīng)該都使用或者聽說過Google提供的Guava工具包。日常使用最多的肯定是集合相關(guān)的工具類,還有Guava cache,除了這些之外Guava還提供了很多有用的功能,鑒于日常想用的時候找不到,這里就梳理一下Guava中那些好用的工具類,想優(yōu)化代碼的時候不妨過來看看
    2021-04-04
  • java實現(xiàn)簡單的爬蟲之今日頭條

    java實現(xiàn)簡單的爬蟲之今日頭條

    最近在學(xué)習(xí)搜索方面的東西,需要了解網(wǎng)絡(luò)爬蟲方面的知識,雖然有很多開源的強(qiáng)大的爬蟲,但本著學(xué)習(xí)的態(tài)度,想到之前在做資訊站的時候需要用到爬蟲來獲取一些文章,今天剛好有空就研究了一下.在網(wǎng)上看到了一個demo,使用的是Jsoup,我拿過來修改了一下,有需要的朋友可以參考
    2016-11-11
  • 簡單的java圖片處理類(圖片水印 圖片縮放)

    簡單的java圖片處理類(圖片水印 圖片縮放)

    本圖片處理類功能非常之強(qiáng)大可以實現(xiàn)幾乎所有WEB開發(fā)中對圖像的處理功能都集成了,包括有縮放圖像、切割圖像、圖像類型轉(zhuǎn)換、彩色轉(zhuǎn)黑白、文字水印、圖片水印等功能
    2013-11-11
  • SpringBoot使用OpenCV的超詳細(xì)步驟

    SpringBoot使用OpenCV的超詳細(xì)步驟

    最近有個項?需要對圖?圖像進(jìn)?處理,使?到了開源框架OpenCV,所以下面這篇文章主要給大家介紹了關(guān)于SpringBoot使用OpenCV的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-04-04
  • Java中局部變量和成員變量的區(qū)別詳解

    Java中局部變量和成員變量的區(qū)別詳解

    這篇文章主要介紹了Java中局部變量和成員變量的區(qū)別,本文將通過示例為大家詳細(xì)講講Java中成員變量與局部變量之間的區(qū)別,感興趣的同學(xué)可以了解一下
    2023-05-05
  • 使用Gradle做Java代碼質(zhì)量檢查的方法示例

    使用Gradle做Java代碼質(zhì)量檢查的方法示例

    這篇文章主要介紹了使用Gradle做Java代碼質(zhì)量檢查的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • SpringBoot給類進(jìn)行賦初值的四種方式

    SpringBoot給類進(jìn)行賦初值的四種方式

    這篇文章主要介紹了springboot給類進(jìn)行賦初值的四種方式,并通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-08-08
  • Mybatis中的config.xml配置文件詳細(xì)解析

    Mybatis中的config.xml配置文件詳細(xì)解析

    這篇文章主要介紹了詳解Mybatis-config.xml配置文件,需要的朋友可以參考下
    2017-12-12
  • Java使用反射創(chuàng)建對象示例

    Java使用反射創(chuàng)建對象示例

    這篇文章主要介紹了Java使用反射創(chuàng)建對象,結(jié)合實例形式分析了java使用反射創(chuàng)建對象的具體實現(xiàn)方法及相關(guān)操作技巧,需要的朋友可以參考下
    2019-07-07
  • Java實現(xiàn)CSV格式轉(zhuǎn)對象

    Java實現(xiàn)CSV格式轉(zhuǎn)對象

    csv全稱“Comma-Separated Values”,是一種逗號分隔值格式的文件,常用來存儲數(shù)據(jù)的純文本格式文件。本文將用Java語言實現(xiàn)CSV轉(zhuǎn)對象,需要的可以參考一下
    2022-06-06

最新評論