返回顶部
首页 > 资讯 > 精选 >怎样使用MyBatis轻松实现递归查询与存储过程调用
  • 615
分享到

怎样使用MyBatis轻松实现递归查询与存储过程调用

2023-06-19 13:06:10 615人浏览 泡泡鱼
摘要

怎样使用mybatis轻松实现递归查询与存储过程调用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。递归调用由于部门的层级不可控,因此如果我想要获取所有部门的完整JSON的话,就

怎样使用mybatis轻松实现递归查询与存储过程调用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

递归调用

由于部门的层级不可控,因此如果我想要获取所有部门的完整JSON的话,就要采用递归调用,使用Java代码处理递归有点low,刚好MyBatis的ResultMap中的collection可以很方便的解决这个问题,核心代码如下:

<resultMap id="BaseResultMap" type="org.sang.bean.Department">    <id property="id" column="id"/>    <result column="name" property="name"/>    <result column="parentId" property="parentId"/>    <result column="isParent" property="isParent"/>    <collection property="children" ofType="org.sang.bean.Department" select="org.sang.mapper.DepartmentMapper.getDepByPid" column="id">    </collection></resultMap><select id="getDepByPid" resultMap="BaseResultMap">    select d1.*from department d1 where d1.`parentId`=#{pid} AND d1.enabled=true;</select>

每一个Department中都有一个children属性,getDepByPid方法的返回结果是一个BaseResultMap,BaseResultMap中的collection又将调用getDepByPid方法,通过这种方式我们可以快速实现一个递归调用。Mapper中只需要定义如下方法即可:

List<Department> getDepByPid(Long pid);

查询结果如下(部分):

[    {        "id": 1,        "name": "股东会",        "parentId": -1,        "enabled": true,        "children": [            {                "id": 4,                "name": "董事长",                "parentId": 1,                "enabled": true,                "children": [                    {                        "id": 5,                        "name": "总经理",                        "parentId": 4,                        "enabled": true,                        "children": [                            {                                "id": 8,                                "name": "财务部",                                "parentId": 5,                                "enabled": true,                                "children": [],                                "parent": false                            }],                        "parent": true                    }                ],                "parent": true            }        ],        "parent": true    }]

存储过程调用

存储过程调用比较简单,以添加部门为例,如下:

Mapper中添加如下方法:

void aDDDep(@Param("dep") Department department);

xml中写法如下:

<select id="addDep" statementType="CALLABLE">    call addDep(#{dep.name,mode=IN,jdbcType=VARCHAR},#{dep.parentId,mode=IN,jdbcType=INTEGER},#{dep.enabled,mode=IN,jdbcType=BOOLEAN},#{dep.result,mode=OUT,jdbcType=INTEGER},#{dep.id,mode=OUT,jdbcType=BIGINT})</select>

注意statementType调用表示这是一个存储过程,mode=IN表示这是输入参数,mode=OUT表示这是输出参数,调用成功之后,在service中获取department的id和result字段,就能拿到相应的调用结果了。

看完上述内容,你们掌握怎样使用MyBatis轻松实现递归查询与存储过程调用的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: 怎样使用MyBatis轻松实现递归查询与存储过程调用

本文链接: https://lsjlt.com/news/296109.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作