Mybatis?在?insert?插入操作后返回主鍵?id的操作方法
Mybatis 在 insert 插入操作后返回主鍵 id
前提條件
假設(shè)我們這里有一個(gè) Student 表,結(jié)構(gòu)如下
sid | name | age |
---|---|---|
101 | Jone | 18 |
102 | Jack | 20 |
103 | Tom | 28 |
其中主鍵 sid 是自增的,那么我們插入數(shù)據(jù)時(shí)就不用插入 sid,它會(huì)生成一個(gè)自增的 sid。
問題提出
這里有一個(gè)問題,我們執(zhí)行插入語句之后,并不能獲取到生成的 sid。
StudentDao 接口中的 insert 方法
boolean insertStudent(Student student);
StudentDao.xml 中的 insert 標(biāo)簽
<insert id="insertStudent" parameterType="Student"> insert into student(name, age) VALUES (#{name} , #{age}) </insert>
單元測(cè)試類中的方法
@Test public void insertUser() { Student student = new Student(0,"xxx", 28); boolean flag = studentDao.insertStudent(student); System.out.println(flag); System.out.println(student); }
執(zhí)行后的結(jié)果
這里并不能獲取到生成的 sid,如果要獲取這個(gè) sid,還要根據(jù) name 來查詢數(shù)據(jù)庫,而且 name 也需要是 unique 唯一性的。
那么,有沒有辦法讓我們能夠執(zhí)行插入語句后,直接獲取到生成的 sid 呢,當(dāng)然是有的。
解決方法
方法一
修改 StudentDao.xml 中的 insert 標(biāo)簽,配置 useGeneratedKeys 和 keyProperty
<insert id="insertStudent" parameterType="Student" useGeneratedKeys="true" keyProperty="sid"> insert into student(name, age) VALUES (#{name} , #{age}) </insert>
說明:
1、useGeneratedKeys=“true” 表示給主鍵設(shè)置自增長(zhǎng)。
2、keyProperty=“sid” 表示將自增長(zhǎng)后的 Id 賦值給實(shí)體類中的 sid 字段。
運(yùn)行結(jié)果:成功返回了主鍵 sid
方法二(推薦)
修改 StudentDao.xml 中的 insert 標(biāo)簽,在 insert 標(biāo)簽中編寫 selectKey 標(biāo)簽
<insert id="insertStudent" parameterType="Student" useGeneratedKeys="true" keyProperty="sid"> insert into student(name, age) VALUES (#{name} , #{age}) </insert>
說明:
1、< insert> 標(biāo)簽中沒有 resultType 屬性,但是 < selectKey> 標(biāo)簽是有的。
2、order=“AFTER” 表示先執(zhí)行插入語句,之后再執(zhí)行查詢語句。
3、keyProperty=“sid” 表示將自增長(zhǎng)后的 Id 賦值給實(shí)體類中的 sid 字段。
4、SELECT LAST_INSERT_ID() 表示 MySQL 語法中查詢出剛剛插入的記錄自增長(zhǎng) Id。
運(yùn)行結(jié)果:成功返回了主鍵 sid
方法三
這種方法需要在一定條件下才能使用,就是 name 需要是 unique,不可重復(fù)的。
這樣才能在插入后,根據(jù) name 來查詢出主鍵 sid。
同樣是修改 StudentDao.xml 中的 insert 標(biāo)簽,在 insert 標(biāo)簽中編寫 selectKey 標(biāo)簽
<insert id="insertStudent" parameterType="Student"> insert into student(name, age) VALUES (#{name} , #{age}) <selectKey keyProperty="sid" order="AFTER" resultType="int"> select sid from student where name = #{name} </selectKey> </insert>
原理上面也講了,就是在執(zhí)行插入語句之后,再執(zhí)行查詢語句,將 sid 查出來。
不過我這里 name 并未設(shè)置 unique,所以不在這里進(jìn)行測(cè)試,有興趣可以自行測(cè)試。
補(bǔ)充知識(shí)點(diǎn):
mybatis中Insert語句如何返回插入的主鍵
方法一:
mapper.java
/** * 添加部門 * @param department * @return */ Integer insertDep(Department department);
xml
<insert id="insertDep" parameterType="com.example.pojo.entity.Department"> <selectKey keyProperty="departmentId" order="AFTER" resultType="java.lang.Integer "> select LAST_INSERT_ID() </selectKey> insert into sys_department(name,parentId,enabled,isParent) VALUES(#{name},#{parentId},1,0) </insert>
其中:
selectKey標(biāo)簽:將插入到數(shù)據(jù)庫的某條記錄的主鍵,返回到指定對(duì)象(user)對(duì)應(yīng)屬性中。
keyProperty: 指定返回的主鍵,存儲(chǔ)在對(duì)象中(user)的哪個(gè)屬性
order:相對(duì)于insert語句,selectKey標(biāo)簽中的sql的執(zhí)行順序。由于mysql的自增原理,執(zhí)行完insert語句之后才將主鍵生成,所以這里selectKey的執(zhí)行順序?yàn)閍fter。
resultType: 返回的主鍵對(duì)應(yīng)的JAVA類型
LAST_INSERT_ID(): 是mysql的函數(shù),返回auto_increment自增列新記錄id值。
方法二
使用:
useGeneratedKeys="true" keyProperty="departmentId"
<insert id="insertDep" parameterType="com.example.pojo.entity.Department" useGeneratedKeys="true" keyProperty="departmentId"> insert into sys_department(departmentId,name,parentId,enabled,isParent) VALUES(uuid(),#{name},#{parentId},1,0) </insert>
到此這篇關(guān)于mybatis中Insert語句如何返回插入的主鍵的文章就介紹到這了,更多相關(guān)mybatis Insert返回插入的主鍵內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java8時(shí)間轉(zhuǎn)換(LocalDateTime)代碼實(shí)例
這篇文章主要介紹了java8時(shí)間轉(zhuǎn)換(LocalDateTime)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11List集合對(duì)象中按照不同屬性大小排序的實(shí)例
下面小編就為大家?guī)硪黄狶ist集合對(duì)象中按照不同屬性大小排序的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03java.lang.UnsupportedClassVersionError錯(cuò)誤的解決辦法(附圖文)
這篇文章主要給大家介紹了關(guān)于java.lang.UnsupportedClassVersionError錯(cuò)誤的解決辦法,"java.lang.UnsupportedClassVersionError"意味著您正在運(yùn)行的Java版本與編譯該類時(shí)使用的Java版本不兼容,需要的朋友可以參考下2023-10-10詳解MyBatis?ResultSetHandler?結(jié)果集的解析過程
這篇文章主要為大家介紹了MyBatis?ResultSetHandler?結(jié)果集的解析過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02ConcurrentHashMap?存儲(chǔ)結(jié)構(gòu)源碼解析
這篇文章主要為大家介紹了ConcurrentHashMap?存儲(chǔ)結(jié)構(gòu)源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10使用Jackson實(shí)現(xiàn)Map與Bean互轉(zhuǎn)方式
這篇文章主要介紹了使用Jackson實(shí)現(xiàn)Map與Bean互轉(zhuǎn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08