第一步:
在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執行完插入語句後,自動將自增長值賦值給對象Spares的屬性id。因此,可通過Spares對應的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返回插入數據的自增長id
今天測試反饋一個bug,現像是新註冊的用戶可以看到所有人的報告,老用戶沒問題,查看日誌發現原來查詢的時候是新註冊的用戶的id為null,所以進行了全表有效數據查詢。 但是表的主鍵不允許為空,怎麼會出現新的註冊用戶id為null呢?原因是在service層代碼直接將參數對象返回了,而xml沒有做任何配置。
具體的解決方案是在xml中的insert方法配置
useGeneratedKeys=”true” keyProperty=”registerId”
keyProperty值對應實體VO對像中的主鍵屬性
具體如下:
<code>@Override public Registers create(Registers r) { registersMapper.insert(r); return r; }</code>registermapper.xml的insert方法如下:
<code><insert id="insert" keyproperty="registerId" parametertype="com.ciji.zzaservice.pojo.base.Registers" usegeneratedkeys="true">
執行正常的insert語句
</insert></code>
這樣在controller層就可以得到新插入數據的自增長主鍵了。
關於在xml中添加兩個屬性的意思,網上解釋如下:
useGeneratedKeys
(僅對insert有用)這會告訴MyBatis使用JDBC的getGeneratedKeys方法來取出由數據(比如:像MySQL和SQL Server這樣的數據庫管理系統的自動遞增字段)內部生成的主鍵。默認值:false。
keyProperty
(僅對insert有用)標記一個屬性,MyBatis會通過getGeneratedKeys或者通過insert語句的selectKey子元素設置它的值。默認:不設置。
總結
以上所述是小編給大家介紹的MyBatis獲取插入記錄的自增長字段值(ID),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!