Spring+MyBatis使用collection标签的两种使用方法

目录

项目场景:

实战操作:

1.创建菜单表

2.创建实体

3.创建Mapper

4.创建xml

属性描述:

效率比较:


项目场景:

本文说明了Spring Boot+MyBatis使用collection标签的两种使用方法

  1. 方法一: 关联查询

  2. 方法二: 嵌套select查询


实战操作:

1.创建菜单表

这里只创建一张表,树结构只有两级,方便学习,多表关联是同样的道理

c 复制代码
-- ----------------------------
-- Table structure for menu
-- ----------------------------
DROP TABLE IF EXISTS `menu`;
CREATE TABLE `menu`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '角色名称',
  `pid` int(3) NULL DEFAULT NULL COMMENT '0代表父级',
  `order` int(3) NULL DEFAULT NULL COMMENT '排序',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 6 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of menu
-- ----------------------------
INSERT INTO `menu` VALUES (1, '审核', 0, 1);
INSERT INTO `menu` VALUES (2, '栏目管理', 0, 2);
INSERT INTO `menu` VALUES (3, '应用审核', 1, 1);
INSERT INTO `menu` VALUES (4, '服务审核', 1, 2);
INSERT INTO `menu` VALUES (5, '角色管理', 2, 1);

2.创建实体

java 复制代码
package com.test.entity;

import lombok.Data;
import java.util.List;

@Data
public class Menu {

    private Integer id;
    private String name;
    private Integer pid;
    private Integer order;

    private List<Menu> menus;

}

3.创建Mapper

java 复制代码
package com.test.dao;

import com.test.entity.Menu;
import java.util.List;

public interface TestMapper{
    //关联查询
	List<Menu> selectMenu();
    //嵌套查询
	List<Menu> selectNestedMenu();
}

4.创建xml

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.test.dao.TestMapper">
    <!-- 公共字段 -->
    <resultMap id="BaseResultMap" type="com.test.entity.Menu">
        <result column="id" property="id"/>
        <result column="name" property="name"/>
        <result column="pid" property="pid"/>
        <result column="order" property="order"/>
    </resultMap>

    <!-- 方式一、关联查询:执行一次sql -->
    <!-- 定义resultMap -->
    <resultMap id="MenuResultMap" extends="BaseResultMap" type="com.test.entity.Menu">
        <!-- 关联集合映射,columnPrefix前缀,用于区分相同字段 -->
        <collection ofType="com.test.entity.Menu" resultMap="BaseResultMap" property="menus" columnPrefix="menu_">
        </collection>
    </resultMap>

    <!-- 查询语句 -->
    <select id="selectMenu" resultMap="MenuResultMap">
        select r.id ,r.name ,r.pid ,r.order ,
               r1.id AS menu_id ,r1.name AS menu_name ,r1.pid AS menu_pid,r1.order AS menu_order
        FROM menu r
        LEFT JOIN menu r1 ON r.id = r1.pid
        where r.pid=0
        order by r.order,r1.order
    </select>

    <!-- 方式二、嵌套查询:会执行多次sql -->
    <!-- 定义resultMap -->
    <resultMap id="NestedResultMap" extends="BaseResultMap" type="com.test.entity.Menu">
        <!-- 嵌套查询集合映射 -->
        <collection property="menus" column="id" select="selectChildMenu"/>
    </resultMap>

    <!-- 查询所有父级语句 -->
    <select id="selectNestedMenu" resultMap="NestedResultMap">
        select r.id ,r.name ,r.pid ,r.order
        FROM menu r
        where r.pid=0
        order by r.order
    </select>

    <!-- 查询下级 -->
    <select id="selectChildMenu" resultMap="BaseResultMap">
        select r.id ,r.name ,r.pid ,r.order
        FROM menu r
        where r.pid=#{id}
        order by r.order
    </select>

</mapper>

属性描述:

|--------------|---------------------------------------------------------------------------|
| 属性 | 描述 |
| property | 属性名:映射实体类属性名 |
| ofType | 映射集合的类型(指定一对多的集合里面元素的类型) |
| column | 映射数据库字段名,传多个 {"属性名"="参数","属性名"="参数"} |
| select | 用于加载复杂类型属性的映射语句的ID(它会从column 属性指定的列中检索数据,作为参数传递给目标 select 语句) |
| columnPrefix | 给关联的数据库中的 column 添加一个前缀(如果不添加前缀,当 两个表同时有 id 字段,查询结果时一定会产生覆盖,使得两个 id 的值一样) |


效率比较:

方法一(关联查询):只需要执行一次sql语句。

方法二(嵌套select查询):需要执行多次sql语句。

方法一比方法二的效率要高,但是在使用的时候,方法二的代码可重用性要高

比如:这里用的是菜单表,数据量不会太大,可以选择方法二(嵌套select查询)

源码: https://download.csdn.net/download/u011974797/88305627

相关推荐
Yaml433 分钟前
Spring Boot 与 Vue 共筑二手书籍交易卓越平台
java·spring boot·后端·mysql·spring·vue·二手书籍
aloha_7891 小时前
从零记录搭建一个干净的mybatis环境
java·笔记·spring·spring cloud·maven·mybatis·springboot
毕业设计制作和分享2 小时前
ssm《数据库系统原理》课程平台的设计与实现+vue
前端·数据库·vue.js·oracle·mybatis
wyh要好好学习3 小时前
SpringMVC快速上手
java·spring
尢词3 小时前
SpringMVC
java·spring·java-ee·tomcat·maven
wrx繁星点点3 小时前
享元模式:高效管理共享对象的设计模式
java·开发语言·spring·设计模式·maven·intellij-idea·享元模式
paopaokaka_luck5 小时前
基于Spring Boot+Vue的助农销售平台(协同过滤算法、限流算法、支付宝沙盒支付、实时聊天、图形化分析)
java·spring boot·小程序·毕业设计·mybatis·1024程序员节
咕哧普拉啦5 小时前
乐尚代驾十订单支付seata、rabbitmq异步消息、redisson延迟队列
java·spring boot·mysql·spring·maven·乐尚代驾·java最新项目
cooldream20096 小时前
Spring Boot中集成MyBatis操作数据库详细教程
java·数据库·spring boot·mybatis
wyh要好好学习6 小时前
SSM— spring,springMVC,mybatis整合
java·spring