MybatisPlus中的save方法详解

 更新时间:2023年11月23日 11:38:09   作者:蓝胖子不是胖子  
save方法是Mybatis-plus框架提供的一个添加记录的方法,它用于将一个实体对象插入到数据库表中,这篇文章主要介绍了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版十大排序经典算法:完整代码(3)

    java版十大排序经典算法:完整代码(3)

    优秀的文章也不少,但是Java完整版的好像不多,我把所有的写一遍巩固下,同时也真诚的希望阅读到这篇文章的小伙伴们可以自己去从头敲一遍,不要粘贴复制!希望我的文章对你有所帮助,每天进步一点点
    2021-07-07
  • mybatis if标签使用总结

    mybatis if标签使用总结

    这篇文章主要介绍了mybatis if标签使用总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • 详解Spring Data JPA动态条件查询的写法

    详解Spring Data JPA动态条件查询的写法

    本篇文章主要介绍了Spring Data JPA动态条件查询的写法 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • SpringBoot集成Sharding Jdbc使用复合分片的实践

    SpringBoot集成Sharding Jdbc使用复合分片的实践

    数据库分库分表中间件是采用的 apache sharding。本文主要介绍了SpringBoot集成Sharding Jdbc使用复合分片的实践,具有一定的参考价值,感兴趣的可以了解一下
    2021-09-09
  • 新版本Spring中lombok失效的问题解决

    新版本Spring中lombok失效的问题解决

    Lombok是一个Java库,通过添加注解简化代码编写,本文主要介绍了新版本Spring中lombok失效的问题解决,感兴趣的可以了解一下
    2025-01-01
  • 一文带你解读所有HashMap的面试题

    一文带你解读所有HashMap的面试题

    HashMap在面试的时候,是非常容易被问到的。因为在JDK8出来之后,非常容易被问到关于HashMap的知识点,而如果对于没有研究过他的源代码的同学来说,这个可能只是说出一部分来。本文就把HashMap上面大部分会被在面试中问到的内容,做个总结,希望有所帮助
    2022-09-09
  • 关于MyBatisSystemException异常产生的原因及解决过程

    关于MyBatisSystemException异常产生的原因及解决过程

    文章讲述了在使用MyBatis进行数据库操作时遇到的异常及其解决过程,首先考虑了事务问题,但未解决,接着怀疑是MyBatis的一级缓存问题,关闭缓存后问题依旧存在,最终发现是SQL映射文件中的参数传递错误,使用了错误的标签导致循环插入
    2025-01-01
  • JAVA编程实现UDP网络通讯的方法示例

    JAVA编程实现UDP网络通讯的方法示例

    这篇文章主要介绍了JAVA编程实现UDP网络通讯的方法,简单说明了UDP通讯的原理并结合实例形式分析了java实现UDP通讯的相关类与使用技巧,需要的朋友可以参考下
    2017-08-08
  • java Spring的启动原理详解

    java Spring的启动原理详解

    大家好,本篇文章主要讲的是java Spring的启动原理详解,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • Java基于Socket实现HTTP下载客户端

    Java基于Socket实现HTTP下载客户端

    这篇文章主要介绍了Java基于Socket实现HTTP下载客户端的相关资料,感兴趣的小伙伴们可以参考一下
    2016-01-01

最新评论