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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

mybatis的SelectKey属性的作用

發(fā)布時間:2024/1/23 编程问答 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybatis的SelectKey属性的作用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?視頻課堂?https://edu.csdn.net/course/play/8034

SelectKey在Mybatis中是為了解決Insert數(shù)據(jù)時不支持主鍵自動生成的問題,他可以很隨意的設置生成主鍵的方式。

?使用mybatis的selectKey就可以得到sequence的值,同時也會將值返回。不過對于不同的數(shù)據(jù)庫有不同的操作方式。

屬性描述
keyPropertyselectKey 語句結果應該被設置的目標屬性。
resultType結果的類型。MyBatis 通常可以算出來,但是寫上也沒有問題。MyBatis 允許任何簡單類型用作主鍵的類型,包括字符串。
order這可以被設置為 BEFORE 或 AFTER。如果設置為 BEFORE,那么它會首先選擇主鍵,設置 keyProperty 然后執(zhí)行插入語句。如果設置為 AFTER,那么先執(zhí)行插入語句,然后是 selectKey 元素-這和如 Oracle 數(shù)據(jù)庫相似,可以在插入語句中嵌入序列調用。
statementType和前面的相 同,MyBatis 支持 STATEMENT ,PREPARED 和CALLABLE 語句的映射類型,分別代表 PreparedStatement 和CallableStatement 類型。

?

SelectKey需要注意order屬性,像MySQL一類支持自動增長類型的數(shù)據(jù)庫中,order需要設置為after才會取到正確的值。

像Oracle這樣取序列的情況,需要設置為before,否則會報錯。

下面是一個xml和注解的例子,SelectKey很簡單,兩個例子就夠了:

<insert id="insert" parameterType="map"> insert into table1 (name) values (#{name}) <selectKey resultType="java.lang.Integer" keyProperty="id"> CALL IDENTITY() </selectKey> </insert>

上面xml的傳入?yún)?shù)是map,selectKey會將結果放到入?yún)?shù)map中。用POJO的情況一樣,但是有一點需要注意的是,keyProperty對應的字段在POJO中必須有相應的setter方法,setter的參數(shù)類型還要一致,否則會報錯。

? 對于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之前執(zhí)行(order="BEFORE"),該句話執(zhí)行完之后,會生成一個ID,傳進來的參數(shù)User對象里的id字段就會被賦值成sequence的值。?

對于mysql?

<insert id="insertUser" parameterClass="XXX.User"> insert into user (name,password) values (#{id},#{name},#{password}) <selectKey resultClass="long" keyProperty="id" order="after"> SELECT LAST_INSERT_ID() AS ID </selectKey> </insert>

? ?將selectKey放在insert之后,通過LAST_INSERT_ID() 獲得剛插入的自動增長的id的值。插入之后獲得ID賦值到傳進來的對象中(對象中必須有相應的屬性)。

像如下本身是Mysql或SqlServer的數(shù)據(jù)庫,沒有必要這樣使用,有點浪費。

<!--保存用戶--><insert id="saveUser" parameterType="com.aaa.entity.User"><selectKey keyProperty="id" keyColumn="id" resultType="int" order="AFTER">select last_insert_id()</selectKey>insert user(id,name,birth,gender,address)values(#{id},#{name},#{birth},#{gender},#{address})</insert>

報錯:Field 'id' doesn't have a default value

配置了SELECT LAST_INSERT_ID()后,需要把表結構的id字段設置為自增屬性AUTO_INCREMENT
以上

總結

以上是生活随笔為你收集整理的mybatis的SelectKey属性的作用的全部內容,希望文章能夠幫你解決所遇到的問題。

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