小編這次要給大家分享的是詳解Mybatis如何實(shí)現(xiàn)插入數(shù)據(jù)后返回主鍵,文章內(nèi)容豐富,感興趣的小伙伴可以來(lái)了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

為巴彥淖爾等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及巴彥淖爾網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為網(wǎng)站建設(shè)、成都做網(wǎng)站、巴彥淖爾網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專(zhuān)業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
添加記錄后獲取主鍵ID,這是一個(gè)很常見(jiàn)的需求,特別是在一次前端調(diào)用中需要插入多個(gè)表的場(chǎng)景。
除了添加單條記錄時(shí)獲取主鍵值,有時(shí)候可能需要獲取批量添加記錄時(shí)各記錄的主鍵值,MyBatis從3.3.1版本開(kāi)始支持批量添加記錄并返回各記錄主鍵字段值。
一、獲取新添加記錄主鍵字段值
注意: 在MyBatis中添加操作返回的是記錄數(shù)并非記錄主鍵id。
如果需要獲取新添加記錄的主鍵值,需要在執(zhí)行添加操作之后,直接讀取Java對(duì)象的主鍵屬性。
Integer rows = sqlSession.getMapper(UserMapper.class).insertUser(user);
System.out.println("rows = " + rows); // 添加操作返回記錄數(shù)
System.out.println("id = " + user.getId()); // 執(zhí)行添加操作之后通過(guò)Java對(duì)象獲取主鍵屬性值
二、在映射器中配置獲取記錄主鍵值
1.xml映射器
在定義xml映射器時(shí)設(shè)置屬性u(píng)seGeneratedKeys值為true,并分別指定屬性keyProperty和keyColumn為對(duì)應(yīng)的數(shù)據(jù)庫(kù)記錄主鍵字段與Java對(duì)象的主鍵屬性。
1.1 插入單條記錄
<mapper namespace="com.dafeng.dao.mapper">
<!-- 插入數(shù)據(jù):返回記錄主鍵id值 -->
<insert id="insertUser" parameterType="com.dafeng.model.User" useGeneratedKeys="true" keyProperty="id" keyColumn="id" >
insert into user(name,age,create_time,update_time) values(#{name},#{age},now(),now())
</insert>
</mapper>1.2 插入多條記錄
<!-- 批量添加數(shù)據(jù),并返回主鍵字段 -->
<insert id="insertBatchUser" useGeneratedKeys="true" keyProperty="id">
INSERT INTO user(name,age,create_time,update_time) VALUES
<foreach collection="list" separator="," item="u">
(#{u.name},#{u.age},now(),now())
</foreach>
</insert>2.接口映射器
在接口映射器中通過(guò)注解@Options分別設(shè)置參數(shù)useGeneratedKeys,keyProperty,keyColumn值
2.1 插入單條記錄
// 返回主鍵字段id值
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
@Insert("insert into user(name,age,create_time,update_time) values(#{name},#{age},now(),now())")
Integer insertUser(User user);
2.2 插入多條記錄
如果希望執(zhí)行批量添加并返回各記錄主鍵字段值,只能在xml映射器中實(shí)現(xiàn),在接口映射器中無(wú)法做到。
看完這篇關(guān)于詳解Mybatis如何實(shí)現(xiàn)插入數(shù)據(jù)后返回主鍵的文章,如果覺(jué)得文章內(nèi)容寫(xiě)得不錯(cuò)的話,可以把它分享出去給更多人看到。
文章題目:詳解Mybatis如何實(shí)現(xiàn)插入數(shù)據(jù)后返回主鍵
路徑分享:http://chinadenli.net/article38/pgjesp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化、App設(shè)計(jì)、網(wǎng)站策劃、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)