MybatisPlus的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进行数据插入时,自动获取到自增主键的值,并将其填充到对应的对象中。这样就可以实现类似的功能。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
在使用Mybatis-plus的save方法时,根据引用和引用的内容,我们可以得出以下结论: - 通过save方法保存实体对象时,会返回受影响的行数,而不是主键id的值。 - 如果需要获取主键id值,需要从传入的对象中获取,例如通过adjustBillInfo.getId()来获取。 - Mybatis-plus在寻找主键的方式上有两种情况: 1. 如果你的表存在一个名为id的字段,Mybatis-plus会将该字段视为主键。 2. 如果你给表字段增加了@TableId注解(注意不要用错成@TableField注解),那么该字段会被标记为主键,优先级比id字段更高。 此外,根据引用的内容,Mybatis-plus默认使用的主键生成策略是IdType.ID_WORKER,它会根据类型随机生成一个全局唯一的ID。如果插入的数据带有id且数据库中存在相同id的记录,那么save方法会执行修改操作;如果数据库中不存在相同id的记录,那么save方法会执行插入操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [mybatis或者mybatis-plus中save方法返回主键值](https://blog.csdn.net/u010459738/article/details/109534480)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [今天来说说mybatis-plus的saveOrUpdate方法(个人笔记)](https://blog.csdn.net/qq_45928041/article/details/123200954)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蓝胖子不是胖子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值