当前位置: 首页 > news >正文

mybatis-plus + springboot 多对多实例

在MyBatis Plus中,自动填充数据是一种非常实用的功能,它可以自动地为一些字段设置默认值,比如创建时间和更新时间。对于多对多关系来说,虽然自动填充主要针对单一实体的字段,但在某些情况下,你可能也需要在创建或更新实体时自动填充与之相关的多对多关系。
下面我将展示如何在实体类中使用MyBatis Plus的自动填充功能,并且给出一个简单的多对多关系示例。


实体类定义
假设我们有两个实体类:Student 和 Course,它们之间存在多对多关系。我们将定义这两个实体类,并为它们添加自动填充字段。

// Student.java
@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName("student")
public class Student {@TableId(type = IdType.AUTO)private Long id;private String name;@ApiModelProperty(value = "创建时间")@TableField(fill = FieldFill.INSERT)private LocalDateTime createTime;@ApiModelProperty(value = "更新时间")@TableField(fill = FieldFill.INSERT_UPDATE)private LocalDateTime updateTime;@TableField(exist = false)private List<Course> courses;
}// Course.java
@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName("course")
public class Course {@TableId(type = IdType.AUTO)private Long id;private String name;@ApiModelProperty(value = "创建时间")@TableField(fill = FieldFill.INSERT)private LocalDateTime createTime;@ApiModelProperty(value = "更新时间")@TableField(fill = FieldFill.INSERT_UPDATE)private LocalDateTime updateTime;@TableField(exist = false)private List<Student> students;
}

这里我们使用了@TableField(fill = FieldFill.INSERT)和@TableField(fill = FieldFill.INSERT_UPDATE)注解来指定哪些字段应该在插入时和更新时自动填充。
自动填充处理器
为了使自动填充生效,你需要定义一个MetaObjectHandler实现类,并在Spring容器中注册它。

@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {@Overridepublic void insertFill(MetaObject metaObject) {this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now());this.strictInsertFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());}@Overridepublic void updateFill(MetaObject metaObject) {this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());}
}

这里我们重写了insertFill和updateFill方法,当实体插入或更新时,这些方法会被自动调用以填充指定的字段。
多对多关系处理
对于多对多关系的处理,你可以选择以下几种方式之一:
使用中间表:定义一个中间表来存储多对多关系,然后在插入或更新实体时,手动处理中间表的插入或更新。
使用注解:如果MyBatis Plus支持多对多关系的注解处理,那么你可以使用相应的注解来简化多对多关系的处理。
由于MyBatis Plus本身并不直接支持多对多关系的注解处理,这里我们采用第一种方式,即定义中间表并手动处理。
中间表定义

@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName("student_course")
public class StudentCourse {@TableId(type = IdType.AUTO)private Long id;private Long studentId;private Long courseId;@ApiModelProperty(value = "创建时间")@TableField(fill = FieldFill.INSERT)private LocalDateTime createTime;@ApiModelProperty(value = "更新时间")@TableField(fill = FieldFill.INSERT_UPDATE)private LocalDateTime updateTime;
}

Mapper接口定义

@Mapper
public interface StudentMapper extends BaseMapper<Student> {// 定义自定义方法
}@Mapper
public interface CourseMapper extends BaseMapper<Course> {// 定义自定义方法
}@Mapper
public interface StudentCourseMapper extends BaseMapper<StudentCourse> {// 定义自定义方法
}

Service层定义

@Service
public class StudentService {@Autowiredprivate StudentMapper studentMapper;@Autowiredprivate StudentCourseMapper studentCourseMapper;public void addStudentWithCourses(Student student, List<Long> courseIds) {studentMapper.insert(student); // 插入学生List<StudentCourse> studentCourses = courseIds.stream().map(courseId -> new StudentCourse(null, student.getId(), courseId)).collect(Collectors.toList());studentCourseMapper.insertBatch(studentCourses); // 插入多对多关系}
}

Controller定义

@RestController
@RequestMapping("/students")
public class StudentController {@Autowiredprivate StudentService studentService;@PostMappingpublic void addStudentWithCourses(@RequestBody Student student, @RequestParam List<Long> courseIds) {studentService.addStudentWithCourses(student, courseIds);}
}

总结
上述示例展示了如何在实体类中使用MyBatis Plus的自动填充功能。
对于多对多关系,我们定义了一个中间表,并在Service层手动处理了多对多关系的插入。
如果有更复杂的多对多关系需求,你可以根据具体情况进行调整。

http://www.lryc.cn/news/423841.html

相关文章:

  • SpringBoot日志整合
  • 信创教育:培养未来科技创新的生力军
  • slowfast
  • 怎么调试python脚本
  • Flask获取请求信息
  • Overleaf中放置高分辨率图片的方法
  • 【C语言】动态内存管理(malloc,free,calloc,realloc详解 )
  • 如何寻找数值仿真参数最优解?CFD参数优化详解3来袭
  • 虚拟机macos中构建llvm、clang并配置Xcode
  • Java 中的 @SneakyThrows 注解详解:简化异常处理的利与弊
  • 系统编程 day11 进程(线程)3
  • [ Python 原理分析 ]如何实现用户实现博客文章点赞-物联网Python
  • 【47 Pandas+Pyecharts | 杭州二手房数据分析可视化】
  • C++入门基础知识13
  • IP地址证如何实现HTTPS访问?(内网IP、公网IP)
  • 东土科技车规级网络芯片获批量应用
  • nvidia系列教程-AGX-Orin pcie扩展M.2磁盘调试笔记
  • haproxy七层代理知识点以及各种配置
  • uniapp自定义浮动图标、列表布局
  • 学习嵌入式入门(十)高级定时器简介及实验(下)
  • 使用python在不改变原有excel的格式下,修改指定单元格格式
  • MySQL数据库:详细安装与配置指南
  • python爬虫代理IP实战
  • 样式,常用组件
  • Django Project | 云笔记练习项目
  • Zookeeper的监听机制
  • Swift withAnimation 动画完成监听
  • 场外期权交易:找到适合你的那一款
  • Elasticsearch-使用java 批量插入文档
  • 【区块链+食品安全】农业产业全过程溯源云平台 | FISCO BCOS应用案例