中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MyBatis之自查詢使用遞歸實現 N級聯動效果(兩種實現方式)

發布時間:2020-10-07 01:07:22 來源:腳本之家 閱讀:250 作者:啷個哩個啷 欄目:編程語言

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級聯動效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

清涧县| 获嘉县| 兴义市| 吉木萨尔县| 赣州市| 汝州市| 钟祥市| 彰武县| 深州市| 桦川县| 和田县| 新田县| 敖汉旗| 拉萨市| 东平县| 华阴市| 英德市| 石景山区| 乌鲁木齐市| 衡南县| 会宁县| 桐梓县| 楚雄市| 台中市| 同德县| 石棉县| 德安县| 北安市| 宣武区| 越西县| 井研县| 新巴尔虎右旗| 武威市| 玉林市| 镇赉县| 新绛县| 田林县| 万全县| 云浮市| 剑川县| 孟连|