MybatisPlus中的save方法详解
Mybatis-plus是一个基于Mybatis的增强工具库,它可以简化Mybatis的使用,提高数据访问层(DAO)的开发效率。其中,Mybatis-plus框架提供了众多的CRUD(增、删、改、查)操作方法,其中比较常用的方法之一就是save方法。
当我前端传递的是一个整合的数据模型Dto,需要同时插入俩张表,并且其中一张表的属性需要得到另一张表的id,如何实现呢?这个·时候MP封装好的插入方法:save就起了很好的作用
public R<String> SaveNewDish(DishDto dishdto) { // 1. 保存菜品基本信息 log.info("前端接受到的id:{}",dishdto.getId()); save(dishdto); String dishid = dishdto.getId(); log.info("插入数据后接受到的id:{}",dishdto.getId()); }
输出后发现:
说明save方法不但做了插入,还将插入后的id返回复制给了插入的对象
Mybatis 实现则需要
使用Mybatis进行插入操作时,可以通过配置来获取插入后的自增主键值,并将其填充到对应的对象中。
下面是一个演示使用Mybatis实现插入数据并获取自增主键值的示例:
首先,创建一个UserDto类,用于封装用户数据:
public class UserDto { private Long id; private String name; // getter和setter方法... }
然后,创建一个UserMapper接口,定义插入数据的方法:
public interface UserMapper { void insertUser(UserDto userDto); }
接下来,编写UserMapper的XML配置文件,定义和实现插入数据的方法:
<!-- UserMapper.xml --> <mapper namespace="com.example.mapper.UserMapper"> <insert id="insertUser" useGeneratedKeys="true" keyProperty="id"> INSERT INTO user(name) VALUES (#{name}) </insert> </mapper>
在上述配置中,useGeneratedKeys="true"用于开启自动生成主键的功能,keyProperty="id"指定了自动生成主键值后填充到UserDto对象的哪个属性中。
最后,在业务代码中使用UserMapper插入数据,并获取自增主键值:
public class UserService { private UserMapper userMapper; public void saveUser(UserDto userDto) { userMapper.insertUser(userDto); // 执行插入操作 // 插入完成后,userDto的id属性会被自动填充 Long generatedId = userDto.getId(); // 处理其他逻辑... } }
通过上述步骤,你可以实现在使用Mybatis进行数据插入时,自动获取到自增主键的值,并将其填充到对应的对象中。这样就可以实现类似的功能。
到此这篇关于MybatisPlus的save方法的文章就介绍到这了,更多相关MybatisPlus save方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
java数组排序示例(冒泡排序、快速排序、希尔排序、选择排序)
java中在运用数组进行排序功能时,一般有四种方法:快速排序法、冒泡法、选择排序法、插入排序法(希尔排序(Shell Sort)是插入排序的一种),下面是一些示例,需要的朋友可以参考下2014-03-03Spring的RedisTemplate存储的key和value有特殊字符的处理
这篇文章主要介绍了Spring的RedisTemplate存储的key和value有特殊字符的处理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-12-12springboot整合mybatis将sql打印到日志的实例详解
这篇文章主要介绍了springboot整合mybatis将sql打印到日志的实例详解,需要的朋友可以参考下2017-12-12
最新评论