MyBatis獲取插入記錄的自增長(zhǎng)字段值(ID)
第一步:
在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è)的用戶可以看到所有人的報(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方法配置
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è)置。
總結(jié)
以上所述是小編給大家介紹的MyBatis獲取插入記錄的自增長(zhǎng)字段值(ID),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
JVM(Java?Virtual?Machine,Java虛擬機(jī))的作用詳解
JVM是Java語(yǔ)言實(shí)現(xiàn)“一次編寫(xiě),到處運(yùn)行”特性的基石,也是Java平臺(tái)的核心組成部分,其主要作用包括平臺(tái)無(wú)關(guān)性、內(nèi)存管理、運(yùn)行Java程序、安全性以及性能優(yōu)化,通過(guò)這些功能,JVM確保了Java程序的可移植性、高效性和安全性2025-03-03
Java實(shí)現(xiàn)八種排序算法詳細(xì)代碼舉例
排序問(wèn)題一直是程序員工作與面試的重點(diǎn),今天特意整理研究下與大家共勉!這篇文章主要介紹了Java實(shí)現(xiàn)八種排序算法的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-10-10
Java8實(shí)戰(zhàn)之Stream的延遲計(jì)算
JDK中Stream的中間函數(shù)如 filter(Predicate super T>)是惰性求值的,filter并非對(duì)流中所有元素調(diào)用傳遞給它的Predicate,下面這篇文章主要給大家介紹了關(guān)于Java8實(shí)戰(zhàn)之Stream延遲計(jì)算的相關(guān)資料,需要的朋友可以參考下2021-09-09
SpringBoot+fileUpload獲取文件上傳進(jìn)度
這篇文章主要為大家詳細(xì)介紹了SpringBoot+fileUpload獲取文件上傳進(jìn)度,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08
java用靜態(tài)工廠代替構(gòu)造函數(shù)使用方法和優(yōu)缺點(diǎn)
這篇文章主要介紹了java用靜態(tài)工廠代替構(gòu)造函數(shù)使用方法和優(yōu)缺點(diǎn),需要的朋友可以參考下2014-02-02
IDEA maven引入SSL證書(shū)校驗(yàn)問(wèn)題及處理
這篇文章主要討論了在Maven項(xiàng)目中遇到依賴導(dǎo)入問(wèn)題,特別是關(guān)于PKIX路徑構(gòu)建失敗的錯(cuò)誤,文章提供了三種解決方法:手動(dòng)下載依賴、忽略SSL證書(shū)校驗(yàn)以及生成并導(dǎo)入SSL證書(shū),每種方法都有詳細(xì)的步驟和示例代碼,幫助開(kāi)發(fā)者解決這個(gè)問(wèn)題2025-02-02
Maven安裝本地的jar包和創(chuàng)建帶模板的自定義項(xiàng)目的操作過(guò)程
這篇文章主要介紹了Maven安裝本地的jar包和創(chuàng)建帶模板的自定義項(xiàng)目,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-03-03

