Mybatis?在?insert?插入操作后返回主鍵?id的操作方法
Mybatis 在 insert 插入操作后返回主鍵 id
前提條件
假設我們這里有一個 Student 表,結構如下
sid | name | age |
---|---|---|
101 | Jone | 18 |
102 | Jack | 20 |
103 | Tom | 28 |
其中主鍵 sid 是自增的,那么我們插入數(shù)據(jù)時就不用插入 sid,它會生成一個自增的 sid。
問題提出
這里有一個問題,我們執(zhí)行插入語句之后,并不能獲取到生成的 sid。
StudentDao 接口中的 insert 方法
boolean insertStudent(Student student);
StudentDao.xml 中的 insert 標簽
<insert id="insertStudent" parameterType="Student"> insert into student(name, age) VALUES (#{name} , #{age}) </insert>
單元測試類中的方法
@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í)行后的結果
這里并不能獲取到生成的 sid,如果要獲取這個 sid,還要根據(jù) name 來查詢數(shù)據(jù)庫,而且 name 也需要是 unique 唯一性的。
那么,有沒有辦法讓我們能夠執(zhí)行插入語句后,直接獲取到生成的 sid 呢,當然是有的。
解決方法
方法一
修改 StudentDao.xml 中的 insert 標簽,配置 useGeneratedKeys 和 keyProperty
<insert id="insertStudent" parameterType="Student" useGeneratedKeys="true" keyProperty="sid"> insert into student(name, age) VALUES (#{name} , #{age}) </insert>
說明:
1、useGeneratedKeys=“true” 表示給主鍵設置自增長。
2、keyProperty=“sid” 表示將自增長后的 Id 賦值給實體類中的 sid 字段。
運行結果:成功返回了主鍵 sid
方法二(推薦)
修改 StudentDao.xml 中的 insert 標簽,在 insert 標簽中編寫 selectKey 標簽
<insert id="insertStudent" parameterType="Student" useGeneratedKeys="true" keyProperty="sid"> insert into student(name, age) VALUES (#{name} , #{age}) </insert>
說明:
1、< insert> 標簽中沒有 resultType 屬性,但是 < selectKey> 標簽是有的。
2、order=“AFTER” 表示先執(zhí)行插入語句,之后再執(zhí)行查詢語句。
3、keyProperty=“sid” 表示將自增長后的 Id 賦值給實體類中的 sid 字段。
4、SELECT LAST_INSERT_ID() 表示 MySQL 語法中查詢出剛剛插入的記錄自增長 Id。
運行結果:成功返回了主鍵 sid
方法三
這種方法需要在一定條件下才能使用,就是 name 需要是 unique,不可重復的。
這樣才能在插入后,根據(jù) name 來查詢出主鍵 sid。
同樣是修改 StudentDao.xml 中的 insert 標簽,在 insert 標簽中編寫 selectKey 標簽
<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 并未設置 unique,所以不在這里進行測試,有興趣可以自行測試。
補充知識點:
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標簽:將插入到數(shù)據(jù)庫的某條記錄的主鍵,返回到指定對象(user)對應屬性中。
keyProperty: 指定返回的主鍵,存儲在對象中(user)的哪個屬性
order:相對于insert語句,selectKey標簽中的sql的執(zhí)行順序。由于mysql的自增原理,執(zhí)行完insert語句之后才將主鍵生成,所以這里selectKey的執(zhí)行順序為after。
resultType: 返回的主鍵對應的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>
到此這篇關于mybatis中Insert語句如何返回插入的主鍵的文章就介紹到這了,更多相關mybatis Insert返回插入的主鍵內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java.lang.UnsupportedClassVersionError錯誤的解決辦法(附圖文)
這篇文章主要給大家介紹了關于java.lang.UnsupportedClassVersionError錯誤的解決辦法,"java.lang.UnsupportedClassVersionError"意味著您正在運行的Java版本與編譯該類時使用的Java版本不兼容,需要的朋友可以參考下2023-10-10詳解MyBatis?ResultSetHandler?結果集的解析過程
這篇文章主要為大家介紹了MyBatis?ResultSetHandler?結果集的解析過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02