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

作者:啷个哩个啷 时间:2023-04-15 03:34:50 

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级联动

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级联动效果网站的支持!

来源:http://www.cnblogs.com/zhangyu0217----/archive/2017/07/12/7155219.html

标签:mybatis,递归,联动
0
投稿

猜你喜欢

  • 基于springmvc之常用注解,操作传入参数

    2023-03-17 20:49:52
  • Hadoop源码分析六启动文件namenode原理详解

    2021-08-20 01:03:55
  • java编程创建型设计模式单例模式的七种示例

    2023-06-21 08:47:39
  • SpringBoot整合WebService的实现示例

    2023-05-25 12:37:55
  • android RecyclerView实现条目Item拖拽排序与滑动删除

    2023-03-20 20:50:36
  • C#中的委托介绍

    2023-07-27 13:26:23
  • springboot用thymeleaf模板的paginate分页完整代码

    2023-10-21 05:06:05
  • 深入java内存查看与分析详解

    2021-06-14 06:48:45
  • 在多线程中调用winform窗体控件的实现方法

    2023-09-13 09:07:43
  • 关于C语言动态内存管理介绍

    2022-07-31 17:05:32
  • 异步/多线程/任务/并行编程之一:如何选择合适的多线程模型?

    2023-12-17 01:03:21
  • 简单了解JavaBean作用及常用操作

    2023-09-08 19:59:29
  • Java拷贝数组方法Arrays.copyOf()是地址传递的证明实例

    2023-11-08 11:51:29
  • C#中关于double.ToString()的用法

    2021-12-06 13:12:22
  • Android Activity之间的数据传递方法总结

    2023-05-26 03:43:21
  • Java设计模式之java装饰者模式详解

    2023-10-27 06:17:04
  • c#根据文件类型获取相关类型图标的方法代码

    2022-07-30 10:56:41
  • C# 定时器保活机制引起的内存泄露问题解决

    2022-09-19 00:31:33
  • MyBatis如何调用存储过程与存储函数

    2023-06-14 16:10:51
  • ThreadLocal常用方法、使用场景及注意事项说明

    2023-07-22 10:26:41
  • asp之家 软件编程 m.aspxhome.com