MyBatis獲取插入記錄的自增長字段值(ID)
第一步:
在Mybatis Mapper文件中添加屬性“useGeneratedKeys
”和“keyProperty
”,其中keyProperty
是Java對象的屬性名!
<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í)行完插入語句后,自動將自增長值賦值給對象Spares的屬性id。因此,可通過Spares對應(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剛剛插入記錄的主鍵自增長值為:" + spares.getId());
ps:mybatis返回插入數(shù)據(jù)的自增長id
今天測試反饋一個bug,現(xiàn)象是新注冊的用戶可以看到所有人的報告,老用戶沒問題,查看日志發(fā)現(xiàn)原來查詢的時候是新注冊的用戶的id為null,所以進行了全表有效數(shù)據(jù)查詢。 但是表的主鍵不允許為空,怎么會出現(xiàn)新的注冊用戶id為null呢?原因是在service層代碼直接將參數(shù)對象返回了,而xml沒有做任何配置。
具體的解決方案是在xml中的insert方法配置
useGeneratedKeys=”true” keyProperty=”registerId”
keyProperty值對應(yīng)實體VO對象中的主鍵屬性
具體如下:
<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語句
</insert></code>
這樣在controller層就可以得到新插入數(shù)據(jù)的自增長主鍵了。
關(guān)于在xml中添加兩個屬性的意思,網(wǎng)上解釋如下:
useGeneratedKeys
(僅對insert有用)這會告訴MyBatis使用JDBC的getGeneratedKeys方法來取出由數(shù)據(jù)(比如:像MySQL和SQL Server這樣的數(shù)據(jù)庫管理系統(tǒng)的自動遞增字段)內(nèi)部生成的主鍵。默認值:false。
keyProperty
(僅對insert有用)標記一個屬性,MyBatis會通過getGeneratedKeys或者通過insert語句的selectKey子元素設(shè)置它的值。默認:不設(shè)置。
總結(jié)
以上所述是小編給大家介紹的MyBatis獲取插入記錄的自增長字段值(ID),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Java中StringBuilder字符串類型的操作方法及API整理
Java中的StringBuffer類繼承于AbstractStringBuilder,用來創(chuàng)建非線程安全的字符串類型對象,下面即是對Java中StringBuilder字符串類型的操作方法及API整理2016-05-05Idea 2020.2 創(chuàng)建web、Spring項目的教程圖解
這篇文章主要介紹了Idea 2020.2 創(chuàng)建web、Spring項目的教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08一分鐘掌握Java?ElasticJob分布式定時任務(wù)
ElasticJob?是面向互聯(lián)網(wǎng)生態(tài)和海量任務(wù)的分布式調(diào)度解決方案,本文主要通過簡單的示例帶大家深入了解ElasticJob分布式定時任務(wù)的相關(guān)知識,需要的可以參考一下2023-05-05JAVA實現(xiàn)基于皮爾遜相關(guān)系數(shù)的相似度詳解
這篇文章主要介紹了JAVA實現(xiàn)基于皮爾遜相關(guān)系數(shù)的相似度詳解,具有一定參考價值,需要的朋友可以了解下。2017-11-11SpringBoot 改造成https訪問的實現(xiàn)
這篇文章主要介紹了SpringBoot 改造成https訪問的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10Mybatis-Plus中update()和updateById()將字段更新為null
本文主要介紹了Mybatis-Plus中update()和updateById()將字段更新為null,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08