职场小白,边学边记
做项目遇到一个返回二层嵌套的三级目录的问题,第一次用框架,好多地方不懂,查了许多资料终于解决了这个问题
解决办法
写了三个Bean
- 第一个:嵌套二级目录的一级目录
- 第二个:嵌套三级目录的二级目录
- 第三个:三级目录
ResultMap可以嵌套,这里不做赘述,代码里可以直观看见
(个人认为实际上写两个ResultMap就可以满足,二三层写到一起)
关键点
写SQL时根据关系写出一条查询语句,直接映射为一对多对多的关系 我的是三个层级的目录通过一个parent字段存在一个表里,不同情况不同讨论,但是实现目标是一致的,即形成一对多对多的关系映射(其实就是两个一对多连在了一块)
Bean的设计
最外层整体目录
public class WholeCatalogEntity {
//一级目录Id
private BigInteger title;
// 一级目录名称
private String key;
// 二级目录
private List<SecondCatalogEntity> children;
}
中间层目录
public class SecondCatalogEntity {
//二级目录Id
private BigInteger title;
//二级目录名称
private String key