怎么使用SpringBoot+MyBatisPlus+MySQL8实现树形结构查询

场景:

实现权限功能模块时,需要将查询的权限数据,以树形结构的方式返回给前端。

功能实现:

第一步:权限表结构定义及其功能演示数据。

DROP TABLE IF EXISTS `baoan_privilege`;CREATE TABLE `baoan_privilege`  (  `id` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '主键',  `privilege_name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '权限名称',  `privilege_code` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '权限编码',  `pid` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '父Id',  `url` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '菜单路由',  `order_rank` int(3) NULL DEFAULT NULL COMMENT '序号',  `privilege_type` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '权限类型1:项目,2菜单,3按钮',  `privilege_description` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '权限描述',  `state` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '2' COMMENT '状态(1:禁用,2:启用)',  `created_by` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '创建人',  `created_dt` datetime(0) NULL DEFAULT NULL COMMENT '创建时间',  `version` int(9) NULL DEFAULT 1 COMMENT '版本号',  `updated_by` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '更新人',  `updated_dt` datetime(0) NULL DEFAULT NULL COMMENT '更新时间',  `icon_name` int(15) NULL DEFAULT NULL COMMENT '图标名称',  `delete_flag` int(1) NULL DEFAULT 1 COMMENT '删除标识(1:未删除,2:已删除)',  PRIMARY KEY (`id`) USING BTREE) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '权限表' ROW_FORMAT = Dynamic; -- ------------------------------ Records of baoan_privilege-- ----------------------------INSERT INTO `baoan_privilege` VALUES ('1', '首页', 'A', '0', NULL, NULL, '1', '首页', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('10', '通知管理', 'F_02', '6', NULL, NULL, '2', '通知管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('11', '操作日志', 'F_03', '6', NULL, NULL, '2', '操作日志', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('12', '角色管理', 'F_04', '6', NULL, NULL, '2', '角色管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('13', '存储管理', 'F_05', '6', NULL, NULL, '2', '存储管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('14', '权限管理', 'F_06', '6', NULL, NULL, '2', '权限管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('15', '新增', 'F_01_add', '9', NULL, NULL, '3', '管理员新增', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('16', '修改', 'F_01_update', '9', NULL, NULL, '3', '管理员修改', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('17', '查询', 'F_01_search', '9', NULL, NULL, '3', '管理员查询', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('18', '删除', 'F_01_delete', '9', NULL, NULL, '3', '管理员删除', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('19', '导出', 'F_01_export', '9', NULL, NULL, '3', '管理员导出', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('2', '用户管理', 'B', '0', NULL, NULL, '1', '用户管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('3', '商场管理', 'C', '0', NULL, NULL, '1', '商场管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('4', '商品管理', 'D', '0', NULL, NULL, '1', '商品管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('5', '推广管理', 'E', '0', NULL, NULL, '1', '推广管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('6', '系统管理', 'F', '0', NULL, NULL, '1', '系统管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('7', '配置管理', 'G', '0', NULL, NULL, '1', '配置管理', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('8', '统计报表', 'H', '0', NULL, NULL, '1', '统计报表', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);INSERT INTO `baoan_privilege` VALUES ('9', '管理员', 'F_01', '6', NULL, NULL, '2', '管理员', '2', NULL, NULL, 1, NULL, NULL, NULL, 1);

第二步:权限表实体定义及其拓展对象

基本对象

package com.zzg.entity; import java.io.Serializable;import java.util.Date; import com.baomidou.mybatisplus.annotation.TableName; import lombok.Data; @SuppressWarnings("serial")@TableName(value = "baoan_privilege")@Datapublic class BaoanPrivilege implements Serializable { private String id;     private String privilegeName;     private String privilegeCode;     private String pid;     private String url;     private Integer orderRank;     private String privilegeType;     private String privilegeDescription;     private String state;     private String createdBy;     private Date createdDt;     private Integer version;     private String updatedBy;     private Date updatedDt;     private Integer iconName;     private Integer deleteFlag;}

拓展对象

package com.zzg.vo; import java.util.List; import com.zzg.entity.BaoanPrivilege; import lombok.Data; @SuppressWarnings("serial")@Datapublic class BaoanPrivilegeVo  extends BaoanPrivilege {  private List children;}

第三步:权限表Mapper 定义

mapper 接口定义

package com.zzg.mapper; import java.util.List;import java.util.Map; import org.apache.ibatis.annotations.Param; import com.baomidou.mybatisplus.core.mapper.BaseMapper;import com.baomidou.mybatisplus.core.metadata.IPage;import com.baomidou.mybatisplus.extension.plugins.pagination.Page;import com.zzg.entity.BaoanPrivilege;import com.zzg.vo.BaoanPrivilegeVo; public interface BaoanPrivilegeMapper extends BaseMapper { List selectList(Map parameter);  IPage selectPage(Page page, @Param("vo")Map parameter);}

mapper.xml 文件定义

                                                                                     id, privilege_name, privilege_code, pid, url, order_rank, privilege_type, privilege_description,     state, created_by, created_dt, version, updated_by, updated_dt, icon_name, delete_flag             and baoan_privilege.privilege_type = #{privilegeType}          and baoan_privilege.pid = #{pid}                and baoan_privilege.privilege_type = #{vo.privilegeType}          and baoan_privilege.pid = #{vo.pid}          SELECT   FROM baoan_privilege WHERE pid = #{id}       select      FROM baoan_privilege    WHERE 1 = 1             select      FROM baoan_privilege    WHERE 1 = 1       

第三步:权限表Service 定义

package com.zzg.service; import java.util.List;import java.util.Map; import com.baomidou.mybatisplus.core.metadata.IPage;import com.baomidou.mybatisplus.extension.plugins.pagination.Page;import com.baomidou.mybatisplus.extension.service.IService;import com.zzg.entity.BaoanPrivilege;import com.zzg.vo.BaoanPrivilegeVo; public interface BaoanPrivilegeService extends IService { List selectList(Map parameter);  IPage selectPage(Page page, Map parameter);}
package com.zzg.service.impl; import java.util.List;import java.util.Map; import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service; import com.baomidou.mybatisplus.core.metadata.IPage;import com.baomidou.mybatisplus.extension.plugins.pagination.Page;import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;import com.zzg.entity.BaoanPrivilege;import com.zzg.mapper.BaoanPrivilegeMapper;import com.zzg.service.BaoanPrivilegeService;import com.zzg.vo.BaoanPrivilegeVo; @Servicepublic class BaoanPrivilegeServiceImpl extends ServiceImpl implements BaoanPrivilegeService { @Autowired private BaoanPrivilegeMapper mapper;  @Override public List selectList(Map parameter) {  // TODO Auto-generated method stub  return mapper.selectList(parameter); }  @Override public IPage selectPage(Page page, Map parameter) {  // TODO Auto-generated method stub  return mapper.selectPage(page, parameter); } }

第四步:controller 层接口对外提供服务

 // 查 @ApiOperation(httpMethod = "POST", value = "基于分页查询符合条件权限记录") @RequestMapping(value = "/getPage", method = { RequestMethod.POST }) @ApiImplicitParams({   @ApiImplicitParam(name = "username", value = "管理员名称", required = false, dataType = "String", paramType = "query") }) public Result getPage(@RequestBody Map parame) {  // 动态构建添加参数//  QueryWrapper query = new QueryWrapper();//  this.buildQuery(parame, query);   PageParame pageParame = this.initPageBounds(parame);  Page page = new Page(pageParame.getPage(), pageParame.getLimit());  IPage list = baoanPrivilegeService.selectPage(page, parame);  return Result.ok().setDatas(list); }

前端效果展示:

怎么使用SpringBoot+MyBatisPlus+MySQL8实现树形结构查询

以上就是怎么使用SpringBoot+MyBatisPlus+MySQL8实现树形结构查询的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/151399.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月3日 12:09:39
下一篇 2025年12月3日 12:29:12

相关推荐

  • 以太坊合约操作流程运算

    以太坊智能合约操作流程包括六个主要步骤:1. 开发准备阶段需安装Node.js、Solidity编译器、配置开发环境及准备存储;2. 合约编写与编译要求使用Solidity语言定义结构并生成字节码和ABI;3. 部署合约需连接网络、创建交易、签名后广播获取部署地址;4. 合约交互分为读取(call)…

    2025年12月8日
    000
  • 2025币圈最有前景的山寨币盘点(内附平台地址)

    2025年值得关注的%ignore_a_2%包括Solana (SOL)、Chainlink (LINK)、Near Protocol (NEAR)和Arbitrum (ARB),它们分别在交易速度、跨链基础设施、用户友好性和Layer 2生态方面具备优势,并可在主流平台获取。1. Solana凭借…

    2025年12月8日
    000
  • SEC批准后最大赢家:贝莱德IBIT规模达800亿 占比特币市值4.2%

    彭博分析师Eric Balchunas在7月11日通过X平台发布消息称,贝莱德推出的比特币现货ETF IBIT仅用374天时间就使管理资产规模突破800亿美元,成为历史上最快达到这一里程碑的ETF产品,远超此前Vanguard S&P 500 ETF(VOO)所保持的1,814天纪录。 三大…

    2025年12月8日
    000
  • Cathie Wood方舟投资减持Coinbase等加密概念股 套现超1400万美元调整仓位

    正当比特币屡创新高、投资人热血沸腾之际,由「女股神」cathie wood掌舵的资产管理公司「方舟投资(ark invest)」果断获利了结,一口气减持3档加密货币概念股,共套现逾1,400万美元。 根据最新交易记录,方舟旗下主力基金「ARK创新ETF(ARKK)」周四出售16,627股Coinba…

    2025年12月8日
    000
  • 什么是UNUS SED(LEO币)?未来如何?LEO币2025-2030年价格预测

    目录 什么是UNUS SED(LEO)?LEO币当前市场状况和价格影响UNUS SED(LEO)价格的因素LEO币价格预测2025-2026年LEO币价格预测2029-2030年2025-2030年价格预测表总结 随着加密货币市场的不断成熟,像unus sed leo(leo)这样的实用型代币正受到…

    2025年12月8日 好文分享
    000
  • 什么是比特币彩虹图?如何在加密交易中使用?一文介绍

    目录 什么是比特币彩虹图?比特币彩虹图是何时创建的?比特币彩虹图V2与原始版本有何不同?如何使用比特币彩虹图1. 确认比特币当前的价格区间2. 解读加密货币市场情绪3. 与其他指标结合使用4. 计划进场和出场比特币彩虹图可靠吗?比特币彩虹图与其他流行的交易指标有何区别?如何将比特币彩虹图与其他交易工…

    2025年12月8日 好文分享
    000
  • 加密聚焦:Worldcoin、Remittix 与实用性的竞赛

    深入探索worldcoin、remittix及其在现实应用与效用方面的独特方法,了解哪些项目正在吸引投资者的目光。 加密货币领域正不断涌现出创新与潜力。Worldcoin、Remittix等项目正积极争夺行业主导地位。让我们深入了解这些项目的最新动态,看看哪些消息正在引发关注。 Worldcoin(…

    2025年12月8日
    000
  • 狗狗币、Pepe、Brett横扫模因赛道:投机还是新叙事?

    狗狗币、Pepe、Brett正引领模因币热潮,Dogecoin(DOGE)作为鼻祖稳居市值榜首,Pepe(PEPE)凭借社群梗文化实现数百倍涨幅,Brett(BRETT)作为Base链新星以独特视觉风格迅速走红;三者分别于2013年、2023年、2024年发行,技术上Dogecoin基于Liteco…

    2025年12月8日
    000
  • Solana突破接近159美元:看涨势头还是冒险之举?

    solana (sol) 正在试探 159 美元关口,预示着可能迎来一波突破行情。它是否能够冲上 185 美元?还是这只是虚假的上涨信号?本文将深入剖析 solana 的价格走势、关键趋势以及对投资者的影响。 Solana 接近 159 美元:是强势突破还是潜在风险? Solana(SOL)正围绕 …

    2025年12月8日
    000
  • 欧OKX官方正版v6.132.1 安卓最新交易app快速体验

    欧易OKX官方最新版v6.132.1安卓交易App已发布,带来更流畅的数字资产交易体验。1. 版本亮点包括极速撮合引擎、多元化交易支持、界面优化、安全升级及实时行情推送;2. 下载方式涵盖官网链接、APK安装及主流应用商店;3. 性能表现提升明显,启动速度提高18%,用户评价良好,评分达4.7星;4…

    2025年12月8日
    000
  • 氦金加密货币:去中心化无线革命还是虚有其表?

    氦币(helium crypto)正通过其去中心化网络重塑无线通信领域。但要实现广泛普及,它能否突破监管壁垒并应对激烈的市场竞争? 氦币:去中心化无线革命还是炒作过度? 在不断发展的加密货币生态中,氦币(Helium Crypto)作为去中心化无线网络的开拓者,正在引发关注。截至2025年7月11日…

    2025年12月8日
    000
  • 散户热捧比特币:相关平台讨论热度创历史新高

    近期,随着数字资产市场的波动加剧,普通投资者的参与热情空前高涨。各大在线平台关于比特币的讨论量屡创新高,反映出市场关注度的显著提升。本文将梳理当前讨论热度最高的几类平台,并分析这一现象背后的驱动因素。 全球比特币主流交易平台官网汇总 币安Binance:  ()欧易OKX:  () Huobi火币:…

    2025年12月8日
    000
  • DePIN、信用卡与Aethir Credible:加密金融的新时代?

    探索 aethir 与 credible finance 的创新合作:推出由 depin 支持的信用卡和贷款,以及日本将加密货币纳入信用卡奖励体系。 DePIN、信用卡与 Aethir Credible:加密金融迈向新时代? 去中心化物理基础设施(DePIN)正逐步与传统金融融合,并以令人耳目一新的…

    2025年12月8日
    000
  • XRP账本的EVM侧链:TVL激增、机构采用与RLUSD的未来

    探索xrp账本evm侧链的爆发增长:tvl激增与机构对rlusd的支持能否推动xrp迈向主流? XRP账本EVM侧链:TVL飙升、机构参与及RLUSD前景展望 随着XRP账本(XRPL)推出其EVM侧链,并结合Ripple推出的RLUSD稳定币,整个生态系统正引起市场广泛关注。该侧链总锁定价值(TV…

    2025年12月8日
    000
  • 什么是隐含波动率(IV)和Delta?如何利用它们指导交易?

    隐含波动率(IV)反映市场对未来价格波动的预期,Delta衡量期权价格对标的资产价格变化的敏感度。1. 高IV意味着期权价格昂贵,适合卖出策略;低IV则适合买入策略。2. Delta值越高,期权价格与标的资产联动越强,并可近似看作合约到期时处于价内的概率,帮助交易者选择合约、评估风险及构建对冲头寸。…

    2025年12月8日
    000
  • 迷因币的市场周期与表现分析 如何抓住下一个Meme币爆发

    迷因币的市场表现由社区情绪和文化叙事驱动,生命周期通常分为四个阶段:1. 潜伏与诞生期,项目在小众圈子出现,市值低、流动性差但潜在回报高;2. 社区驱动与初步扩散,核心支持者自发传播,社区活跃度是关键指标;3. 媒体关注与加速增长,主流媒体报道引发资金流入,流动性改善,FOMO情绪高涨;4. 顶峰与…

    2025年12月8日
    000
  • 模因硬币躁狂症:狗狗币、柴犬和社区炒作的力量

    2021年,加密货币市场迎来了一场前所未有的“模因硬币躁狂症”,其中狗狗币(dogecoin)和柴犬币(shiba inu)无疑是这场狂潮的焦点。它们的崛起,不仅仅是数字资产价格的飙升,更是一场深刻的社区力量和社交媒体影响力实验。从一个玩笑式的数字小费,到市值一度突破数百亿的巨头,狗狗币的蜕变令人咋…

    2025年12月8日
    000
  • 比特币的复兴:分析2025年的牛市及其驱动因素

    2025年,比特币的复兴并非空穴来风,而是在多重因素交织下形成的必然趋势。全球宏观经济的变动、传统金融市场对数字资产态度的转变、技术创新的不断突破,以及合规化进程的加速,共同为这场牛市奠定了坚实基础。机构投资者的持续入场,不再是试探性的少量配置,而是将其视为资产配置组合中不可或缺的一部分,这种趋势正…

    2025年12月8日
    000
  • 医疗保健、加密货币与比特币储备:探索新前沿

    探索医疗保健、加密货币与战略比特币储备的融合:创新金融、法律挑战与投资策略 医疗、加密货币与比特币储备:驾驭新前沿 医疗保健、加密货币和比特币储备的交汇正在掀起一股浪潮。让我们一起深入了解这一领域的重要进展。 OSR控股的大胆加密布局 OSR控股(OSR Holdings)正通过一项规模达5,000…

    2025年12月8日
    000
  • 币圈空投在哪获取 怎样才能得到空投奖励

    本文将围绕“币圈空投在哪获取”和“怎样才能得到空投奖励”这两个问题进行讲解,帮助用户掌握有效参与空投的方式。 什么是币圈空投 空投是一种数字资产项目方在新币上线前后,用于吸引用户注意力的一种推广方式。通常用户只需完成一些简单任务,如关注社交平台、填写表单、加入社群等,即可获得一定数量的代币奖励。 获…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信