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

目录

项目场景:

实战操作:

1.创建菜单表

2.创建实体 

3.创建Mapper

4.创建xml 

属性描述:

效率比较:


项目场景:

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

1. 方法一: 关联查询
2. 方法二: 嵌套select查询


实战操作:

1.创建菜单表

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

-- ----------------------------
-- 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);

Spring+MyBatis使用collection标签的两种使用方法_第1张图片

2.创建实体 

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 menus;

}

3.创建Mapper

package com.test.dao;

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

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

4.创建xml 




    
    
        
        
        
        
    

    
    
    
        
        
        
    

    
    

    
    
    
        
        
    

    
    

    
    



属性描述:

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

效率比较:

方法一(关联查询):只需要执行一次sql语句。
方法二(嵌套select查询):需要执行多次sql语句。
     
方法一比方法二的效率要高,但是在使用的时候,方法二的代码可重用性要高

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

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

你可能感兴趣的:(后端,spring,mybatis,collection,嵌套查询)