MyBatis递归查询层级关系的树

之前做递归的时候写了那么多java代码发现根本不需要,直接sql就能搞定,直接上代码。

数据:根据parentId查出id,然后把id赋值给parentId,在查处原本parentId下面有哪些级别的数据。

实体类:这里关键是id,和父级parentId有关联关系。另外加一个children,list元素是本实体类。

/**
 * 部门实体
 */
public class Department implements Serializable {
    private Integer id;
    private String name;
    private Integer parentId;
    private String depPath;
    private Boolean enabled;
    private Boolean isParent;
    private List<Department> children;// 子部门
}

dao层:这里传的是父级parentId

    /**
     * mapper接口
     */
    List<Department> getAllDepartments(Integer parentId);

xml:

    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="com.cdh.server.pojo.Department">
        <id column="id" property="id"/>
        <result column="name" property="name"/>
        <result column="parentId" property="parentId"/>
        <result column="depPath" property="depPath"/>
        <result column="enabled" property="enabled"/>
        <result column="isParent" property="isParent"/>
    </resultMap>
	<!-- 相当于id=-1 查询的结果id,再用这个id调用自己方法查询 -->
    <resultMap id="DepartmentMap" type="com.cdh.server.pojo.Department" extends="BaseResultMap">
        <collection
                property="children"
                ofType="com.cdh.server.pojo.Department"
                select="com.cdh.server.mapper.DepartmentMapper.getAllDepartments"
                column="id">
        </collection>
    </resultMap>

    <!--查询所有部门-->
    <select id="getAllDepartments" resultMap="DepartmentMap">
    select id, name, parentId, depPath, enabled, isParent
    from t_department
    where parentId = #{parentId}
    </select>

结果展示:

相关推荐
嵌入式郑工2 小时前
ssh,samba,tftp,nfs服务安装和配置
java·前端·ssh
顽疲3 小时前
从零用java实现 小红书 springboot vue uniapp (10)系统消息模块 接收推送消息优化
java·vue.js·spring boot·uni-app
!!!5253 小时前
Mybatis-底层是如何解决sql注入&增删改查操作--删除操作
java·spring boot·mybatis
程序员buddha4 小时前
华为OD上机考试真题(Java)——最长方连续方波信号
java·开发语言·华为od
程序员buddha4 小时前
华为OD上机考试真题(Java)——排队游戏
java·游戏·华为od
CodeClimb4 小时前
【华为OD-E卷 - 整数编码 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
CodeClimb4 小时前
【华为OD-E卷 - IPv4地址转换成整数 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
arnold664 小时前
华为OD E卷(100分)53-TLV解码
java·算法·华为od
life or die4 小时前
Kafka权威指南(第2版)读书笔记
java·kafka