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

MyBatis獲取插入記錄的自增長(zhǎng)字段值(ID)

 更新時(shí)間:2017年11月22日 11:13:32   作者:robot_man  
本文分步驟給大家介紹了MyBatis獲取插入記錄的自增長(zhǎng)字段值的方法,在文中給大家提到了mybatis返回插入數(shù)據(jù)的自增長(zhǎng)id,需要的朋友可以參考下

第一步:

    在Mybatis Mapper文件中添加屬性“useGeneratedKeys”和“keyProperty”,其中keyProperty是Java對(duì)象的屬性名!

<insert id="insert" parameterType="Spares" 
 useGeneratedKeys="true" keyProperty="id">
 insert into spares(spares_id,spares_name,
  spares_type_id,spares_spec)
 values(#{id},#{name},#{typeId},#{spec})
 </insert>

第二步:

    Mybatis執(zhí)行完插入語(yǔ)句后,自動(dòng)將自增長(zhǎng)值賦值給對(duì)象Spares的屬性id。因此,可通過(guò)Spares對(duì)應(yīng)的getter方法獲??!

 /**
 * 新增備件
 * @author hellostory
 * @param spares
 * @return
 */
 @RequestMapping(value = "/insert")
 @ResponseBody
 public JsonResponse insert(Spares spares) {
 int count = sparesService.insert(spares);
 System.out.println("共插入" + count + "條記錄!"
  + "\n剛剛插入記錄的主鍵自增長(zhǎng)值為:" + spares.getId());

ps:mybatis返回插入數(shù)據(jù)的自增長(zhǎng)id

今天測(cè)試反饋一個(gè)bug,現(xiàn)象是新注冊(cè)的用戶可以看到所有人的報(bào)告,老用戶沒(méi)問(wèn)題,查看日志發(fā)現(xiàn)原來(lái)查詢的時(shí)候是新注冊(cè)的用戶的id為null,所以進(jìn)行了全表有效數(shù)據(jù)查詢。 但是表的主鍵不允許為空,怎么會(huì)出現(xiàn)新的注冊(cè)用戶id為null呢?原因是在service層代碼直接將參數(shù)對(duì)象返回了,而xml沒(méi)有做任何配置。

具體的解決方案是在xml中的insert方法配置

useGeneratedKeys=”true” keyProperty=”registerId”

keyProperty值對(duì)應(yīng)實(shí)體VO對(duì)象中的主鍵屬性

具體如下:

<code class="hljs java">@Override
  public Registers create(Registers r) {
    registersMapper.insert(r);
    return r;
  }</code>

registermapper.xml的insert方法如下:

<code class="hljs xml"><insert id="insert" keyproperty="registerId" parametertype="com.ciji.zzaservice.pojo.base.Registers" usegeneratedkeys="true">

執(zhí)行正常的insert語(yǔ)句

</insert></code>

這樣在controller層就可以得到新插入數(shù)據(jù)的自增長(zhǎng)主鍵了。

關(guān)于在xml中添加兩個(gè)屬性的意思,網(wǎng)上解釋如下:

useGeneratedKeys

(僅對(duì)insert有用)這會(huì)告訴MyBatis使用JDBC的getGeneratedKeys方法來(lái)取出由數(shù)據(jù)(比如:像MySQL和SQL Server這樣的數(shù)據(jù)庫(kù)管理系統(tǒng)的自動(dòng)遞增字段)內(nèi)部生成的主鍵。默認(rèn)值:false。

keyProperty

(僅對(duì)insert有用)標(biāo)記一個(gè)屬性,MyBatis會(huì)通過(guò)getGeneratedKeys或者通過(guò)insert語(yǔ)句的selectKey子元素設(shè)置它的值。默認(rèn):不設(shè)置。

總結(jié)

以上所述是小編給大家介紹的MyBatis獲取插入記錄的自增長(zhǎng)字段值(ID),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Java中StringBuilder字符串類(lèi)型的操作方法及API整理

    Java中StringBuilder字符串類(lèi)型的操作方法及API整理

    Java中的StringBuffer類(lèi)繼承于AbstractStringBuilder,用來(lái)創(chuàng)建非線程安全的字符串類(lèi)型對(duì)象,下面即是對(duì)Java中StringBuilder字符串類(lèi)型的操作方法及API整理
    2016-05-05
  • java實(shí)現(xiàn)簡(jiǎn)單圖書(shū)管理系統(tǒng)

    java實(shí)現(xiàn)簡(jiǎn)單圖書(shū)管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單圖書(shū)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • SpringMVC整合kinfe4j及問(wèn)題解決分析

    SpringMVC整合kinfe4j及問(wèn)題解決分析

    這篇文章主要為大家介紹了SpringMVC整合kinfe4j及問(wèn)題解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • Idea 2020.2 創(chuàng)建web、Spring項(xiàng)目的教程圖解

    Idea 2020.2 創(chuàng)建web、Spring項(xiàng)目的教程圖解

    這篇文章主要介紹了Idea 2020.2 創(chuàng)建web、Spring項(xiàng)目的教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • 一分鐘掌握J(rèn)ava?ElasticJob分布式定時(shí)任務(wù)

    一分鐘掌握J(rèn)ava?ElasticJob分布式定時(shí)任務(wù)

    ElasticJob?是面向互聯(lián)網(wǎng)生態(tài)和海量任務(wù)的分布式調(diào)度解決方案,本文主要通過(guò)簡(jiǎn)單的示例帶大家深入了解ElasticJob分布式定時(shí)任務(wù)的相關(guān)知識(shí),需要的可以參考一下
    2023-05-05
  • JAVA實(shí)現(xiàn)基于皮爾遜相關(guān)系數(shù)的相似度詳解

    JAVA實(shí)現(xiàn)基于皮爾遜相關(guān)系數(shù)的相似度詳解

    這篇文章主要介紹了JAVA實(shí)現(xiàn)基于皮爾遜相關(guān)系數(shù)的相似度詳解,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • Springboot整合log4j2日志全解總結(jié)

    Springboot整合log4j2日志全解總結(jié)

    這篇文章主要介紹了Springboot整合log4j2日志全解總結(jié),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • SpringBoot 改造成https訪問(wèn)的實(shí)現(xiàn)

    SpringBoot 改造成https訪問(wèn)的實(shí)現(xiàn)

    這篇文章主要介紹了SpringBoot 改造成https訪問(wèn)的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-10-10
  • Mybatis-Plus中update()和updateById()將字段更新為null

    Mybatis-Plus中update()和updateById()將字段更新為null

    本文主要介紹了Mybatis-Plus中update()和updateById()將字段更新為null,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 深入淺出講解Java8函數(shù)式編程

    深入淺出講解Java8函數(shù)式編程

    不管是前端還是后端開(kāi)發(fā)人員,學(xué)習(xí)一些函數(shù)式編程的思想和概念,對(duì)于手頭的開(kāi)發(fā)工作和以后的職業(yè)發(fā)展,都是大有裨益的,下面這篇文章主要給大家介紹了關(guān)于Java8函數(shù)式編程的相關(guān)資料,需要的朋友可以參考下
    2022-01-01

最新評(píng)論