当我前端传递的是一个整合的数据模型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进行数据插入时,自动获取到自增主键的值,并将其填充到对应的对象中。这样就可以实现类似的功能。












![P31[10-1]软件模拟IIC通信协议(使用stm32库函数)(内含:实物连接+IIC时序解释+硬件电路+IIC基本时序单元(起始 终止 发送接收 ))](https://img-blog.csdnimg.cn/8daa1d681c6e45aa986067e0d8329314.png)





