>  기사  >  Java  >  MyBatis는 자체 쿼리를 수행하고 재귀를 사용하여 N 수준 연결을 구현합니다.

MyBatis는 자체 쿼리를 수행하고 재귀를 사용하여 N 수준 연결을 구현합니다.

巴扎黑
巴扎黑원래의
2017-07-21 14:38:592005검색

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로 pid가 0인 cid를 사용합니다.

        public List<Category> getCategory(Integer pid);   //接口层方法
매핑 파일 Configuration

<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

은 모두 객체 유형을 지정합니다. 차이점은 역방향 쿼리 선택을 사용하여 다른 매퍼 파일에서 데이터를 검색할 때 ofType을 사용해야 한다는 것입니다

둘 다 사용할 수 있습니다. 개체 유형을 지정합니다.

작성에는 필요하지 않으며 역선택에는 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으로 문의하세요.
이전 기사:자바 면접 질문과 답변 (4)다음 기사:자바 면접 질문과 답변 (4)

관련 기사

더보기