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

mybatis新增save結(jié)束后自動返回主鍵id詳解

 更新時間:2021年12月03日 15:48:11   作者:xy405580364  
這篇文章主要介紹了mybatis新增save結(jié)束后自動返回主鍵id詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

mybatis新增save結(jié)束后自動返回主鍵id

1.使用場景

save操作之前實體類中id為null,save之后自動返回帶id的實體類

@Override
    public ChartPagePanel save(ChartPagePanel entity) {
        UserDetails user = SecurityContextHolder.getUserDetails();
        entity.setCreateUser(user.getUsername());
        entity.setLastModifyUser(user.getUsername());
        //entity中的id為null
        chartPagePanelMapper.save(entity);
        //經(jīng)過save操作后自動返回帶id的entity
        // savePanelManage(entity); 其中的entity帶有id
        savePanelManage(entity);
        return entity;
    }

    @Transactional
    public void savePanelManage(ChartPagePanel entity){
        if(entity.getChartPageManges()!=null && entity.getChartPageManges().size()>0) {
            Map<String, Object> map = new HashMap<>();
            for (int i = 0; i < entity.getChartPageManges().size(); i++) {
                int manageId = entity.getChartPageManges().get(i).getId();
                map.put("manageId", manageId);
                map.put("panelId", entity.getId());
                chartPagePanelManageMapper.save(map);
            }
        }
    }

2.原理在Mybatis配置了

useGeneratedKeys=“true” keyProperty=“id”
<insert id="save" parameterType="com.centrin.generator.entity.ChartPagePanel" useGeneratedKeys="true" keyProperty="id">
 insert into chart_page_panel
 (
        `parent_id`,
        `position`,
        `name`,
        `create_time`,
        `create_user`,
        `last_modify_time`,
        `last_modify_user`
        )
 values (
  #{parentId},
  #{position},
  #{name},
  NOW(),
  #{createUser},
  NOW(),
  #{lastModifyUser}
  )
  </insert>

mybatis或者mybatis-plus中save方法返回主鍵值

1.mapper.xml中

方式:

useGeneratedKeys=“true” keyProperty=“id” keyColumn=“id”

解釋:

在xml中定義useGeneratedKeys為true,返回主鍵id的值,keyColumn和keyProperty分別代表數(shù)據(jù)庫記錄主鍵字段和java對象成員屬性名

<insert id="saveBill" parameterType="com.jd.fp.mrp.domain.model.biz.AdjustBillInfo"
        useGeneratedKeys="true" keyProperty="id" keyColumn="id">
        INSERT INTO adjust_bill_info(external_bill_id, warehouse_code, warehouse_name)
        VALUES(#{externalBillId}, #{warehouseCode}, #{warehouseName});
</insert>

2.service或者dao中

注意:通過該種方式得到的結(jié)果是受影響的行數(shù)?。。。。?/p>

如果要獲取主鍵id值,需要從傳入的對象中獲取?。。。?!

Long id = aTranscationMapper.saveBill(adjustBillInfo);
System.out.println("===========保存受影響的行數(shù):"+id+"  保存的id值為:"+adjustBillInfo.getId());

輸出結(jié)果展示:

===========保存受影響的行數(shù):1 保存的id值為:191

mybatis-plus的insert后,返回主鍵id,直接通過傳入的對象獲取id即可!
bizApplicationFormMapper.insert(form);
System.out.println("=============="+form.getId());

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • hadoop?全面解讀自定義分區(qū)

    hadoop?全面解讀自定義分區(qū)

    Hadoop是一個由Apache基金會所開發(fā)的分布式系統(tǒng)基礎(chǔ)架構(gòu)。用戶可以在不了解分布式底層細(xì)節(jié)的情況下,開發(fā)分布式程序。充分利用集群的威力進(jìn)行高速運算和存儲
    2022-02-02
  • SpringCloud?微服務(wù)數(shù)據(jù)權(quán)限控制的實現(xiàn)

    SpringCloud?微服務(wù)數(shù)據(jù)權(quán)限控制的實現(xiàn)

    這篇文章主要介紹的是權(quán)限控制的數(shù)據(jù)權(quán)限層面,意思是控制可訪問數(shù)據(jù)資源的數(shù)量,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-11-11
  • MyBatis?if?test?判斷字符串相等不生效問題

    MyBatis?if?test?判斷字符串相等不生效問題

    這篇文章主要介紹了MyBatis?if?test?判斷字符串相等不生效問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Java利用DelayQueue實現(xiàn)延遲任務(wù)代碼實例

    Java利用DelayQueue實現(xiàn)延遲任務(wù)代碼實例

    這篇文章主要介紹了Java利用DelayQueue實現(xiàn)延遲任務(wù)代碼實例,DelayQueue?是一個支持延時獲取元素的阻塞隊列,?內(nèi)部采用優(yōu)先隊列?PriorityQueue?存儲元素,同時元素必須實現(xiàn)?Delayed?接口,需要的朋友可以參考下
    2023-12-12
  • SpringBoot?Security使用MySQL實現(xiàn)驗證與權(quán)限管理

    SpringBoot?Security使用MySQL實現(xiàn)驗證與權(quán)限管理

    安全管理是軟件系統(tǒng)必不可少的的功能。根據(jù)經(jīng)典的“墨菲定律”——凡是可能,總會發(fā)生。如果系統(tǒng)存在安全隱患,最終必然會出現(xiàn)問題,這篇文章主要介紹了SpringBoot安全管理Spring?Security基本配置
    2022-11-11
  • Spring Boot下的Job定時任務(wù)

    Spring Boot下的Job定時任務(wù)

    編寫Job定時執(zhí)行任務(wù)十分有用,能解決很多問題,這次實習(xí)的項目里做了一下系統(tǒng)定時更新三方系統(tǒng)訂單狀態(tài)的功能,這里用到了Spring的定時任務(wù)使用的非常方便,下面總結(jié)一下如何使用,感興趣的朋友參考下吧
    2017-05-05
  • Java實現(xiàn)的漢語拼音工具類完整實例

    Java實現(xiàn)的漢語拼音工具類完整實例

    這篇文章主要介紹了Java實現(xiàn)的漢語拼音工具類,結(jié)合完整實例形式分析了java基于pinyin4j包實現(xiàn)編碼轉(zhuǎn)換的相關(guān)操作技巧,需要的朋友可以參考下
    2017-11-11
  • Java多文件以ZIP壓縮包導(dǎo)出的實現(xiàn)方法

    Java多文件以ZIP壓縮包導(dǎo)出的實現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了Java多文件以ZIP壓縮包導(dǎo)出的實現(xiàn)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • 使用maven-assembly-plugin如何將system 依賴范圍的jar以class 方式打包進(jìn) jar包中

    使用maven-assembly-plugin如何將system 依賴范圍的jar以class 方式

    這篇文章主要介紹了使用maven-assembly-plugin如何將system 依賴范圍的jar以class 方式打包進(jìn) jar包中,本文給大家分享完美解決思路,結(jié)合實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • java中如何實現(xiàn) zip rar 7z 壓縮包解壓

    java中如何實現(xiàn) zip rar 7z 壓縮包解壓

    這篇文章主要介紹了java中如何實現(xiàn) zip rar 7z 壓縮包解壓問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07

最新評論