MybatisPlus中的save方法詳解
Mybatis-plus是一個基于Mybatis的增強工具庫,它可以簡化Mybatis的使用,提高數據訪問層(DAO)的開發(fā)效率。其中,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());
}輸出后發(fā)現:


說明save方法不但做了插入,還將插入后的id返回復制給了插入的對象
Mybatis 實現則需要
使用Mybatis進行插入操作時,可以通過配置來獲取插入后的自增主鍵值,并將其填充到對應的對象中。
下面是一個演示使用Mybatis實現插入數據并獲取自增主鍵值的示例:
首先,創(chuàng)建一個UserDto類,用于封裝用戶數據:
public class UserDto {
private Long id;
private String name;
// getter和setter方法...
}
然后,創(chuàng)建一個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對象的哪個屬性中。
最后,在業(yè)務代碼中使用UserMapper插入數據,并獲取自增主鍵值:
public class UserService {
private UserMapper userMapper;
public void saveUser(UserDto userDto) {
userMapper.insertUser(userDto); // 執(zhí)行插入操作
// 插入完成后,userDto的id屬性會被自動填充
Long generatedId = userDto.getId();
// 處理其他邏輯...
}
}通過上述步驟,你可以實現在使用Mybatis進行數據插入時,自動獲取到自增主鍵的值,并將其填充到對應的對象中。這樣就可以實現類似的功能。
到此這篇關于MybatisPlus的save方法的文章就介紹到這了,更多相關MybatisPlus save方法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解Spring Data JPA動態(tài)條件查詢的寫法
本篇文章主要介紹了Spring Data JPA動態(tài)條件查詢的寫法 ,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06
SpringBoot集成Sharding Jdbc使用復合分片的實踐
數據庫分庫分表中間件是采用的 apache sharding。本文主要介紹了SpringBoot集成Sharding Jdbc使用復合分片的實踐,具有一定的參考價值,感興趣的可以了解一下2021-09-09
關于MyBatisSystemException異常產生的原因及解決過程
文章講述了在使用MyBatis進行數據庫操作時遇到的異常及其解決過程,首先考慮了事務問題,但未解決,接著懷疑是MyBatis的一級緩存問題,關閉緩存后問題依舊存在,最終發(fā)現是SQL映射文件中的參數傳遞錯誤,使用了錯誤的標簽導致循環(huán)插入2025-01-01

