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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

MyBatis中的selectKey

發布時間:2025/4/16 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MyBatis中的selectKey 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

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

不管SelectKey有多好,盡量不要遇到這種情況吧,畢竟很麻煩。

selectKey Attributes

屬性
描述

keyProperty
selectKey 語句結果應該被設置的目標屬性。

resultType
結果的類型。MyBatis 通??梢运愠鰜?但是寫上也沒有問題。MyBatis 允許任何簡單類型用作主鍵的類型,包括字符串。

order
這可以被設置為 BEFORE 或 AFTER。如果設置為 BEFORE,那么它會首先選擇主鍵,設置 keyProperty 然后執行插入語句。如果設置為 AFTER,那么先執行插入語句,然后是 selectKey 元素-這和如 Oracle 數據庫相似,可以在插入語句中嵌入序列調用。

statementType
和前面的相 同,MyBatis 支持 STATEMENT ,PREPARED 和CALLABLE 語句的映射類型,分別代表 PreparedStatement 和CallableStatement 類型。

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

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

另外在用Spring管理事務時,SelectKey和插入在同一事務當中,因而Mysql這樣的情況由于數據未插入到數據庫中,所以是得不到自動增長的Key。取消事務管理就不會有問題。

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

[html] view plaincopy

  • <insert id="insert" parameterType="map">
  • ??? insert into table1 (name) values (#{name})?
  • <selectKey resultType="java.lang.Integer" keyProperty="id">
  • ????? CALL IDENTITY()?
  • </selectKey>
  • </insert>
  • 上面xml的傳入參數是map,selectKey會將結果放到入參數map中。用POJO的情況一樣,但是有一點需要注意的是,keyProperty對應的字段在POJO中必須有相應的setter方法,setter的參數類型還要一致,否則會報錯。

    [java] view plaincopy

  • @Insert("insert into table2 (name) values(#{name})")?
  • @SelectKey(statement="call identity()", keyProperty="nameId", before=false, resultType=int.class)?
  • int insertTable2(Name name);?
  • 上面是注解的形式。

    在insert語句中,在Oracle經常使用序列、在MySQL中使用函數來自動生成插入表的主鍵,而且需要方法能返回這個生成主鍵。使用myBatis的selectKey標簽可以實現這個效果。

    下面例子,使用mysql數據庫自定義函數nextval('student'),用來生成一個key,并把他設置到傳入的實體類中的studentId屬性上。所以在執行完此方法后,邊可以通過這個實體類獲取生成的key。

    Xml代碼

  • <!-- 插入學生 自動主鍵-->
  • <insert id="createStudentAutoKey" parameterType="liming.student.manager.data.model.StudentEntity" keyProperty="studentId">
  • <selectKey keyProperty="studentId" resultType="String" order="BEFORE">
  • ??????? select nextval('student')?
  • </selectKey>
  • ??? INSERT INTO STUDENT_TBL(STUDENT_ID,?
  • ??????????????????????????? STUDENT_NAME,?
  • ??????????????????????????? STUDENT_SEX,?
  • ??????????????????????????? STUDENT_BIRTHDAY,?
  • ??????????????????????????? STUDENT_PHOTO,?
  • ??????????????????????????? CLASS_ID,?
  • ??????????????????????????? PLACE_ID)?
  • ??? VALUES (#{studentId},?
  • ??????????? #{studentName},?
  • ??????????? #{studentSex},?
  • ??????????? #{studentBirthday},?
  • ??????????? #{studentPhoto, javaType=byte[], jdbcType=BLOB, typeHandler=org.apache.ibatis.type.BlobTypeHandler},?
  • ??????????? #{classId},?
  • ??????????? #{placeId})?
  • </insert>
  • 調用接口方法,和獲取自動生成key

    Java代碼

  • StudentEntity entity = new StudentEntity();?
  • entity.setStudentName("黎明你好");?
  • entity.setStudentSex(1);?
  • entity.setStudentBirthday(DateUtil.parse("1985-05-28"));?
  • entity.setClassId("20000001");?
  • entity.setPlaceId("70000001");?
  • this.dynamicSqlMapper.createStudentAutoKey(entity);?
  • System.out.println("新增學生ID: " + entity.getStudentId());?
  • 轉載于:https://my.oschina.net/u/1784135/blog/388905

    總結

    以上是生活随笔為你收集整理的MyBatis中的selectKey的全部內容,希望文章能夠幫你解決所遇到的問題。

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