MyBatis之自查询使用递归实现 N级联动效果(两种实现方式)

发布时间 - 2026-01-11 02:18:29    点击率:

A:首先先看下一个简单的面试题

斐波那契数列

计算数组{1,1,2,3,5,8.......} 第30位值

规律:1 1 从第三项开始,每一项都是前两项之和

    有两种实现方式

 第一种方式:

public class TestOne {
 public int TestSelf(int n){
  if(n<0){
   throw new IllegalArgumentException("n不能为负数");
  }else if(n<=2){
   return 1;
  }else{
   return TestSelf(n-2)+TestSelf(n-1);
  }
 }
 @Test
 public void Test(){
  System.out.println(TestSelf(30));
 }
}

打印结果832040

第二种方式:利用数组

public int TestSelfTwo(int n){
  if(n<0){
   throw new IllegalArgumentException("n不能为负数");
  }else if(n<=1){ //递归前两个数 不管n是多少 为一
   return 1;
  }
  int[] nums = new int[n+1]; //30位从零开始
  nums[0]=1;
  nums[1]=1;
  for (int i =2;i<n;i++){
   nums[i] = nums[i-2]+nums[i-1];
  }
  return nums[n-1];
 }
 @Test
 public void Test(){
  System.out.println(TestSelfTwo(30));
 }

公式:f(n) = f(n-2)+f(n-1)   f代表方法 n代表多少 位

B:在MyBatis中利用递归实现n级联动

sql语句:select * from type where pid = 0;  首次指定pid值为0,然后下次根据pid为0的cid 作为下次查询的pid 
  public List<Category> getCategory(Integer pid); //接口层方法

映射文件配置

<mapper namespace="dao.CateGoryDao">
 <resultMap id="getSelf" type="entity.Category">
   <id column="cid" property="cid"></id>
   <result column="cname" property="cName"></result>
   <collection property="categorySet" select="getCategory" column="cid"></collection> //这里可以不用指定oftype 使用反向查询select从另一个maper文件中取出数据时必须用ofType
   <!--查到的cid作为下次的pid-->
 </resultMap>
 <select id="getCategory" resultMap="getSelf" >
  select * from category where pid=#{pid}
 </select>
</mapper>

mybatis的javaType和ofType 

都是指定对象的类型 不同的是当使用反向查询select从另一个maper文件中取出数据时必须用ofType

都可以为collection和association是指定对象的类型,

都不是必须写的, 只有反向select时需要ofType;

实体类:

package entity;
import java.util.HashSet;
import java.util.Set;
/**
 * Created by zhangyu on 2017/7/12.
 */
public class Category {
 private Integer cid;
 private String cName;
 private Integer pid;
 private Set<Category> categorySet = new HashSet<Category>();
 @Override
 public String toString() {
  return "Category{" +
    "cid=" + cid +
    ", cName='" + cName + '\'' +
    ", pid=" + pid +
    ", categorySet=" + categorySet +
    '}';
 }
 public Integer getCid() {
  return cid;
 }
 public void setCid(Integer cid) {
  this.cid = cid;
 }
 public String getcName() {
  return cName;
 }
 public void setcName(String cName) {
  this.cName = cName;
 }
 public Integer getPid() {
  return pid;
 }
 public void setPid(Integer pid) {
  this.pid = pid;
 }
 public Set<Category> getCategorySet() {
  return categorySet;
 }
 public void setCategorySet(Set<Category> categorySet) {
  this.categorySet = categorySet;
 }
}

测试类:

 //测试自连接
 @Test
 public void TestSelf(){
  CateGoryDao dao = MyBatis.getSessionTwo().getMapper(CateGoryDao.class);
  List<Category> list = dao.getCategory(0);
  for (Category item:list ) {
   System.out.println(item);
  }
 }

打印结果:

Category{cid=1, cName='图书', pid=0, categorySet=[Category{cid=5, cName='期刊报纸', pid=1, categorySet=[]}, Category{cid=3, cName='青年图书', pid=1, categorySet=[Category{cid=6, cName='读者', pid=3, categorySet=[Category{cid=7, cName='12月份', pid=6, categorySet=[]}]}]}, Category{cid=4, cName='少儿图书', pid=1, categorySet=[]}]}
Category{cid=2, cName='服装', pid=0, categorySet=[]}

以上所述是小编给大家介绍的MyBatis之自查询使用递归实现 N级联动效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# mybatis  # 递归实现n级联动  # MyBatis实现模糊查询的几种方式  # Mybatis多表关联查询的实现(DEMO)  # mybatis 模糊查询的实现方法  # Mybatis 一对多和多对一关联查询问题  # mybatis 实现 SQL 查询拦截修改详解  # Mybatis查询记录条数的实例代码  # MyBatis实现动态查询、模糊查询功能  # Mybatis查询语句结果集的总结大全  # mybatis分页及模糊查询功能实现  # MyBatis查询时属性名和字段名不一致问题的解决方法  # 递归  # 都是  # 下次  # 能为  # 小编  # 的是  # 级联  # 首次  # 在此  # 给大家  # 有两种  # 两项  # 所述  # 第二种  # 第一种  # 先看  # 给我留言  # 值为  # 感谢大家  # 每一项 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  Android Socket接口实现即时通讯实例代码  Android滚轮选择时间控件使用详解  Laravel集合Collection怎么用_Laravel集合常用函数详解  Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  如何生成腾讯云建站专用兑换码?  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  Laravel如何与Pusher实现实时通信?(WebSocket示例)  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  详解Android中Activity的四大启动模式实验简述  Laravel怎么在Controller之外的地方验证数据  如何在宝塔面板中创建新站点?  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  JS去除重复并统计数量的实现方法  Swift中循环语句中的转移语句 break 和 continue  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  如何在VPS电脑上快速搭建网站?  如何构建满足综合性能需求的优质建站方案?  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  微信小程序 input输入框控件详解及实例(多种示例)  如何用AWS免费套餐快速搭建高效网站?  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  西安专业网站制作公司有哪些,陕西省建行官方网站?  如何在腾讯云免费申请建站?  文字头像制作网站推荐软件,醒图能自动配文字吗?  如何在企业微信快速生成手机电脑官网?  详解Android图表 MPAndroidChart折线图  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  EditPlus 正则表达式 实战(3)  Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】  如何在IIS7中新建站点?详细步骤解析  如何在宝塔面板中修改默认建站目录?  Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门  Android实现代码画虚线边框背景效果  济南网站建设制作公司,室内设计网站一般都有哪些功能?  Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】  Java垃圾回收器的方法和原理总结  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?