方法传过来的是list参数,list里面是对象
自关联查询
void save(List<DepartmentCustom> department);<insert id="save" parameterType="java.util.List">
insert into tb_department (enterprise_uid, name,
parent_id, description) values
<if test="list!=null">
<foreach collection="list" item="item" separator="," >
(#{item.enterpriseUid},#{item.name},#{item.parentId},#{item.description})
</foreach>
</if>
</insert>自关联查询
<!-- 针对菜单的父子关系,定义的树状结构ResultMap -->
<resultMap id="menuResultMap" type="com.awcloud.user.pojo.custom.MenuCustom">
<id column="id" property="id" jdbcType="BIGINT" />
<result column="name" property="name" jdbcType="VARCHAR" />
<result column="menu_code" property="menuCode" jdbcType="VARCHAR" />
<result column="parent_id" property="parentId" jdbcType="BIGINT" />
<result column="url" property="url" jdbcType="VARCHAR" />
<result column="order" property="order" jdbcType="INTEGER" />
<result column="type" property="type" jdbcType="INTEGER" />
<result column="icon" property="icon" jdbcType="VARCHAR" />
<result column="description" property="description" jdbcType="VARCHAR" />
<result column="enabled" property="enabled" jdbcType="BIT" />
<!-- 查询子菜单 -->
<collection property="children" column="id" select="getChildrenMenus" />
</resultMap>
<!-- 查询特定menu的所有子菜单,返回menuResultMap -->
<select id="getChildrenMenus" parameterType="int" resultMap="menuResultMap">
select * from tb_menu where parent_id = #{id}
</select>
<!-- 查询所有顶级菜单并且带子菜单集合,返回menuResultMap -->
<select id="getTopLevelMenusWithChildren" resultMap="menuResultMap" >
select * from tb_menu where type=1 and (parent_id IS NULL or parent_id=0)
</select>
本文介绍了一个使用MyBatis实现的批量插入方法,该方法接收一个部门对象列表作为参数,并展示了如何通过XML配置文件进行动态SQL组装。此外,还详细描述了一种自关联查询方式,用于构建树状结构的数据结果集,适用于展示具有层级关系的菜单数据。
1170

被折叠的 条评论
为什么被折叠?



