欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-12-06 13:56:58
a:首先先看下一个简单的面试题 斐波那契数列 计算数组{1,1,2,3,5,8.......} 第30位值 规律:1 1 从第三项开始,每一项都是前两项之和 &nb...

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级联动效果,希望对大家有所帮助