欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MybatisPlus中的save方法詳解

 更新時(shí)間:2023年11月23日 11:38:09   作者:藍(lán)胖子不是胖子  
save方法是Mybatis-plus框架提供的一個(gè)添加記錄的方法,它用于將一個(gè)實(shí)體對(duì)象插入到數(shù)據(jù)庫(kù)表中,這篇文章主要介紹了MybatisPlus中的save方法,需要的朋友可以參考下

Mybatis-plus是一個(gè)基于Mybatis的增強(qiáng)工具庫(kù),它可以簡(jiǎn)化Mybatis的使用,提高數(shù)據(jù)訪問(wèn)層(DAO)的開(kāi)發(fā)效率。其中,Mybatis-plus框架提供了眾多的CRUD(增、刪、改、查)操作方法,其中比較常用的方法之一就是save方法。

當(dāng)我前端傳遞的是一個(gè)整合的數(shù)據(jù)模型Dto,需要同時(shí)插入倆張表,并且其中一張表的屬性需要得到另一張表的id,如何實(shí)現(xiàn)呢?這個(gè)·時(shí)候MP封裝好的插入方法:save就起了很好的作用

    public R<String> SaveNewDish(DishDto dishdto) {
//     1.   保存菜品基本信息
        log.info("前端接受到的id:{}",dishdto.getId());
        save(dishdto);
        String dishid = dishdto.getId();
        log.info("插入數(shù)據(jù)后接受到的id:{}",dishdto.getId());
}

輸出后發(fā)現(xiàn):

在這里插入圖片描述

在這里插入圖片描述

說(shuō)明save方法不但做了插入,還將插入后的id返回復(fù)制給了插入的對(duì)象

Mybatis 實(shí)現(xiàn)則需要
使用Mybatis進(jìn)行插入操作時(shí),可以通過(guò)配置來(lái)獲取插入后的自增主鍵值,并將其填充到對(duì)應(yīng)的對(duì)象中。

下面是一個(gè)演示使用Mybatis實(shí)現(xiàn)插入數(shù)據(jù)并獲取自增主鍵值的示例:

首先,創(chuàng)建一個(gè)UserDto類,用于封裝用戶數(shù)據(jù):

public class UserDto {
    private Long id;
    private String name;
    
    // getter和setter方法...
}

然后,創(chuàng)建一個(gè)UserMapper接口,定義插入數(shù)據(jù)的方法:

public interface UserMapper {
    void insertUser(UserDto userDto);
}

接下來(lái),編寫(xiě)UserMapper的XML配置文件,定義和實(shí)現(xiàn)插入數(shù)據(jù)的方法:

<!-- 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"用于開(kāi)啟自動(dòng)生成主鍵的功能,keyProperty="id"指定了自動(dòng)生成主鍵值后填充到UserDto對(duì)象的哪個(gè)屬性中。

最后,在業(yè)務(wù)代碼中使用UserMapper插入數(shù)據(jù),并獲取自增主鍵值:

public class UserService {
    private UserMapper userMapper;
    public void saveUser(UserDto userDto) {
        userMapper.insertUser(userDto); // 執(zhí)行插入操作
        // 插入完成后,userDto的id屬性會(huì)被自動(dòng)填充
        Long generatedId = userDto.getId();
        // 處理其他邏輯...
    }
}

通過(guò)上述步驟,你可以實(shí)現(xiàn)在使用Mybatis進(jìn)行數(shù)據(jù)插入時(shí),自動(dòng)獲取到自增主鍵的值,并將其填充到對(duì)應(yīng)的對(duì)象中。這樣就可以實(shí)現(xiàn)類似的功能。

到此這篇關(guān)于MybatisPlus的save方法的文章就介紹到這了,更多相關(guān)MybatisPlus save方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java版十大排序經(jīng)典算法:完整代碼(3)

    java版十大排序經(jīng)典算法:完整代碼(3)

    優(yōu)秀的文章也不少,但是Java完整版的好像不多,我把所有的寫(xiě)一遍鞏固下,同時(shí)也真誠(chéng)的希望閱讀到這篇文章的小伙伴們可以自己去從頭敲一遍,不要粘貼復(fù)制!希望我的文章對(duì)你有所幫助,每天進(jìn)步一點(diǎn)點(diǎn)
    2021-07-07
  • mybatis if標(biāo)簽使用總結(jié)

    mybatis if標(biāo)簽使用總結(jié)

    這篇文章主要介紹了mybatis if標(biāo)簽使用總結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 詳解Spring Data JPA動(dòng)態(tài)條件查詢的寫(xiě)法

    詳解Spring Data JPA動(dòng)態(tài)條件查詢的寫(xiě)法

    本篇文章主要介紹了Spring Data JPA動(dòng)態(tài)條件查詢的寫(xiě)法 ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-06-06
  • SpringBoot集成Sharding Jdbc使用復(fù)合分片的實(shí)踐

    SpringBoot集成Sharding Jdbc使用復(fù)合分片的實(shí)踐

    數(shù)據(jù)庫(kù)分庫(kù)分表中間件是采用的 apache sharding。本文主要介紹了SpringBoot集成Sharding Jdbc使用復(fù)合分片的實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-09-09
  • 新版本Spring中l(wèi)ombok失效的問(wèn)題解決

    新版本Spring中l(wèi)ombok失效的問(wèn)題解決

    Lombok是一個(gè)Java庫(kù),通過(guò)添加注解簡(jiǎn)化代碼編寫(xiě),本文主要介紹了新版本Spring中l(wèi)ombok失效的問(wèn)題解決,感興趣的可以了解一下
    2025-01-01
  • 一文帶你解讀所有HashMap的面試題

    一文帶你解讀所有HashMap的面試題

    HashMap在面試的時(shí)候,是非常容易被問(wèn)到的。因?yàn)樵贘DK8出來(lái)之后,非常容易被問(wèn)到關(guān)于HashMap的知識(shí)點(diǎn),而如果對(duì)于沒(méi)有研究過(guò)他的源代碼的同學(xué)來(lái)說(shuō),這個(gè)可能只是說(shuō)出一部分來(lái)。本文就把HashMap上面大部分會(huì)被在面試中問(wèn)到的內(nèi)容,做個(gè)總結(jié),希望有所幫助
    2022-09-09
  • 關(guān)于MyBatisSystemException異常產(chǎn)生的原因及解決過(guò)程

    關(guān)于MyBatisSystemException異常產(chǎn)生的原因及解決過(guò)程

    文章講述了在使用MyBatis進(jìn)行數(shù)據(jù)庫(kù)操作時(shí)遇到的異常及其解決過(guò)程,首先考慮了事務(wù)問(wèn)題,但未解決,接著懷疑是MyBatis的一級(jí)緩存問(wèn)題,關(guān)閉緩存后問(wèn)題依舊存在,最終發(fā)現(xiàn)是SQL映射文件中的參數(shù)傳遞錯(cuò)誤,使用了錯(cuò)誤的標(biāo)簽導(dǎo)致循環(huán)插入
    2025-01-01
  • JAVA編程實(shí)現(xiàn)UDP網(wǎng)絡(luò)通訊的方法示例

    JAVA編程實(shí)現(xiàn)UDP網(wǎng)絡(luò)通訊的方法示例

    這篇文章主要介紹了JAVA編程實(shí)現(xiàn)UDP網(wǎng)絡(luò)通訊的方法,簡(jiǎn)單說(shuō)明了UDP通訊的原理并結(jié)合實(shí)例形式分析了java實(shí)現(xiàn)UDP通訊的相關(guān)類與使用技巧,需要的朋友可以參考下
    2017-08-08
  • java?Spring的啟動(dòng)原理詳解

    java?Spring的啟動(dòng)原理詳解

    大家好,本篇文章主要講的是java?Spring的啟動(dòng)原理詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • Java基于Socket實(shí)現(xiàn)HTTP下載客戶端

    Java基于Socket實(shí)現(xiàn)HTTP下載客戶端

    這篇文章主要介紹了Java基于Socket實(shí)現(xiàn)HTTP下載客戶端的相關(guān)資料,感興趣的小伙伴們可以參考一下
    2016-01-01

最新評(píng)論