SpringBoot之一个TreeNode模块的Demo(使用Mybatis的高级查询实现)

1.声明

当前内容用于本人学习,以及笔记之用,主要解决TreeNode这个问题,例如菜单节点

2.分析类似菜单的实现

1.分析例如菜单的需求
在这里插入图片描述
分析这个需求并实现这个类的数据结构
在这里插入图片描述
分析查询的sql
在这里插入图片描述

3.创建该数据结构TreeNode

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class TreeNode {
	private static final long serialVersionUID = 1L;
	@TableId(value = "id", type = IdType.AUTO)
	private Integer id;
	private String name;
	private Integer parentNodeId;
	private List<TreeNode> childNodes;

}

4.创建TreeNodeMapper和映射xml文件

public interface TreeNodeMapper {
	List<TreeNode> findAllTreeNode();
}

对应的xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper
	namespace="com.hy.springboot.mybatisplus.rolepermiss.mapper.TreeNodeMapper">
	<resultMap type="treeNode" id="tableTreeNode">
		<id column="id" property="id" />
		<result column="name" property="name" />
		<result column="parentNodeId" property="parentNodeId" />
		<collection property="childNodes" select="findTreeNodesByParentNodeId" column="{pid=id}"></collection>
	</resultMap>

	<!-- select * from tree_node where parentNodeId is null SELECT * FROM tree_node 
		WHERE parentNodeId = 1 SELECT * FROM tree_node WHERE parentNodeId = 4 -->
	<select id="findAllTreeNode" resultMap="tableTreeNode">
		select * from tree_node
		where parentNodeId is null
	</select>
	
	<select id="findTreeNodesByParentNodeId" resultMap="tableTreeNode">
		select * from tree_node
		where parentNodeId=#{pid}
	</select>
</mapper>

这里注意的是,collection中使用select查询,返回的结果为resultMap为上面一个tableTreeNode,由此可以实现递归的查询操作

5.创建controller并实现查询操作

@RestController
@RequestMapping("/treeNode")
public class TreeNodeController {
	@Autowired
	TreeNodeMapper treeNodeMapper;

	@RequestMapping("/findAllTreeNode")
	public ResponseEntity<?> findAllTreeNode() {
		List<TreeNode> treeNode = treeNodeMapper.findAllTreeNode();
		return ResponseEntity.ok(treeNode);
	}
}

6.测试

在这里插入图片描述
结果操作成功!

7.总结

1.首先在实现某项功能的时候,需要先分析实现的功能,然后为该功能定义数据结构(数据结构定义最为重要)

2.在实现该查询的时候需要分析该查询是否有规律,有规律可以按照特定的规律实现递归操作,collection中的select,并且select中返回本身resultMap(就可以实现递归操作)

以上纯属个人见解,如有问题请联系本人!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值