這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)使用MyBatis怎么獲取插入記錄的自增長(zhǎng)字段值,文章內(nèi)容豐富且以專(zhuān)業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
目前創(chuàng)新互聯(lián)建站已為上1000+的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站托管維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、右玉網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶(hù)導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶(hù)和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
第一步:
在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è)的用戶(hù)可以看到所有人的報(bào)告,老用戶(hù)沒(méi)問(wèn)題,查看日志發(fā)現(xiàn)原來(lái)查詢(xún)的時(shí)候是新注冊(cè)的用戶(hù)的id為null,所以進(jìn)行了全表有效數(shù)據(jù)查詢(xún)。 但是表的主鍵不允許為空,怎么會(huì)出現(xiàn)新的注冊(cè)用戶(hù)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è)置。
上述就是小編為大家分享的使用MyBatis怎么獲取插入記錄的自增長(zhǎng)字段值了,如果剛好有類(lèi)似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
分享文章:使用MyBatis怎么獲取插入記錄的自增長(zhǎng)字段值
分享鏈接:http://muchs.cn/article16/gjscdg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、企業(yè)建站、定制網(wǎng)站、用戶(hù)體驗(yàn)、網(wǎng)站改版、小程序開(kāi)發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)