第一步:
在Mybatis Mapper文件中添加屬性“useGeneratedKeys
”和“keyProperty
”,其中keyProperty
是Java對(duì)象的屬性名!
1
2
3
4
5
6
|
<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方法獲?。?/p>
1
2
3
4
5
6
7
8
9
10
11
12
|
/** * 新增備件 * @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方法配置
1
|
useGeneratedKeys=” true ” keyProperty=”registerId” |
keyProperty值對(duì)應(yīng)實(shí)體VO對(duì)象中的主鍵屬性
具體如下:
1
2
3
4
5
|
<code class = "hljs java" > @Override public Registers create(Registers r) { registersMapper.insert(r); return r; }</code> |
registermapper.xml的insert方法如下:
1
|
<code class = "hljs xml" ><insert id= "insert" keyproperty= "registerId" parametertype= "com.ciji.zzaservice.pojo.base.Registers" usegeneratedkeys= "true" > |
執(zhí)行正常的insert語(yǔ)句
1
|
</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ù)器之家網(wǎng)站的支持!
原文鏈接:https://my.oschina.net/u/3708595/blog/1577120