首頁  >  文章  >  Java  >  MyBatis自查詢並使用遞歸實作 N級聯動

MyBatis自查詢並使用遞歸實作 N級聯動

巴扎黑
巴扎黑原創
2017-07-21 14:38:592002瀏覽

A:首先先看下一個簡單的面試題

斐波那契數列

#計算陣列{1,1,2,3,5,8..... ..} 第30位元值


 法則:1  1   從第三項開始,每一項都是前兩項之和

    有兩種實現方式

 第一種方式:

   TestSelf((n<0   IllegalArgumentException("n不能为负数" (n<=2 1 TestSelf(n-2)+TestSelf(n-1 30

 

#第二種方式:利用陣列

 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>();
    @Overridepublic 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;
    }
}
 

測試類別:

   

#

 //测试自连接    @Testpublic 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級聯動的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:Java面試題與解答(四)下一篇:Java面試題與解答(四)

相關文章

看更多