日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

insert返回主键 — mybatis selectKey

發布時間:2024/4/14 编程问答 54 豆豆
生活随笔 收集整理的這篇文章主要介紹了 insert返回主键 — mybatis selectKey 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

日常項目開發中,經常會用到一個場景:在表中新增一條數據,需要得到該條數據的主鍵ID。如何不額外寫一條查詢語句來得到新增數據的主鍵ID呢?mybatis的selectKey實現了這個功能。

mybatis的selectKey在不同數據庫中的用法有點區別:

oracle中的用法

<insert id="insertUser" parameterClass="XXX.user"> <selectKey resultClass="long" keyProperty="id"order="BEFORE"> select SEQ_USER_ID.nextval as id from dual </selectKey> insert into user (id,name,password) values (#{id},#{name},#{password}) </insert>

這句話會在插入user之前執行(order=“BEFORE”),該句話執行完之后,通過SEQ_USER_ID.nextval生成一個ID,傳進來的參數User對象里的id字段就會被賦值成sequence的值,通過user.id即可獲取新增數據的主鍵ID。

mysql中的用法

<insert id="insertUser" parameterClass="XXX.user"> insert into user (name,password) values (#{id},#{name},#{password}) <selectKeykeyProperty="id" order="AFTER" resultType="java.lang.Integer"> SELECT LAST_INSERT_ID() AS ID </selectKey> </insert>

該種用法是通過LAST_INSERT_ID() 獲得剛插入的自動增長的id的值。插入之后獲得ID賦值到傳進來的對象中,通過user.id獲取。

SelectKey用法詳解:

1、SelectKey因為可以很隨意的設置生成主鍵的方式,所以用在Mybatis中是為了解決Insert數據時不支持主鍵自動生成的問題。使用它可以得到sequence的值(比如用在oracle中,就可以使用SEQ_USER_ID.nextval來生成一個主鍵),同時也會將值返回。對于不同的數據庫有不同的操作方式。

2、SelectKey標簽中有一個order屬性,在不同的數據庫中有不同的用法:
1)在支持自動增長類型的數據庫(mysql)中,order需要設置為after才會取到正確的值。新增數據的時候mysql數據庫通過自增取得主鍵ID,然后將值返回;
2)像Oracle這樣取序列的情況,需要設置為before。通過序列化方法生成一個主鍵ID,之后插入數據庫。

3、屬性

總結

以上是生活随笔為你收集整理的insert返回主键 — mybatis selectKey的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。