A: 먼저 간단한 면접 질문을 살펴보겠습니다
피보나치 수열
규칙: 1 1 시작 세 번째 항목부터 각 항목은 이전 두 항목의 합입니다.
구현하는 방법에는 두 가지가 있습니다.
첫 번째 방법:
TestSelf((n
두 번째 방법: 배열 사용
public int TestSelfTwo(int n){ if(n
공식: 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); //接口层方法</category>매핑 파일 Configuration
<mapper><resultmap><id></id><result></result><collection></collection> //这里可以不用指定oftype 使用反向查询select从另一个maper文件中取出数据时必须用ofType<!--查到的cid作为下次的pid--></resultmap><select>select * from category where pid=#{pid}</select></mapper>
둘 다 사용할 수 있습니다. 개체 유형을 지정합니다.
작성에는 필요하지 않으며 역선택에는 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; } }</category></category></category></category>
//测试自连接 @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>
결과 인쇄:
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!