您好,登錄后才能下訂單哦!
在Springboot項(xiàng)目中使用MybatisPlus和Oracle實(shí)現(xiàn)主鍵ID的自增?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
application.yml配置
# Mybatis的相關(guān)配置 mybatis-plus: mapper-locations: classpath*:com/XX/XX/XX/dao/mapping/*.xml typeAliasesPackage: com.XX.XX.XX.model global-config: #主鍵類型 0:"數(shù)據(jù)庫ID自增", 1:"用戶輸入ID",2:"全局唯一ID (數(shù)字類型唯一ID)", 3:"全局唯一ID UUID"; id-type: 1 #序列接口實(shí)現(xiàn)類配置 key-generator: com.baomidou.mybatisplus.incrementer.OracleKeyGenerator
model實(shí)體類配置(僅展示id)
import java.io.Serializable; import javax.persistence.*; import lombok.Data; @Data @Table(name = "POJO") public class SysLogeInfo implements Serializable { @Id @Column(name = "ID") @SequenceGenerator(name = "sequenceGenerator",sequenceName = "POJO_SEQ") @GeneratedValue(generator = "sequenceGenerator",strategy = GenerationType.SEQUENCE) private Integer id; }
其中:
@SequenceGenerator的name與@GeneratedValue的generator相對(duì)應(yīng)
sequenceName即你在oracle數(shù)據(jù)庫中為此表創(chuàng)建的自增序列名(貌似框架無法自動(dòng)生成,需要自己手動(dòng)創(chuàng)建)
這樣,主鍵ID插入null值的問題基本解決了,但是我們的Mapper繼承了tk.mybatis.mapper.common.Mapper,插入是直接調(diào)tk.Mapper的insertSelective(T var1)方法,有時(shí)候我們需要插入后的主鍵id,這種方法沒辦法得到,所以只能手寫insert方法,如下。
<insert id="add" keyColumn="ID" keyProperty="id" parameterType="com.XX.XX.XX.model.POJO" useGeneratedKeys="true"> <selectKey resultType="int" order="BEFORE" keyProperty="id"> SELECT POJO_SEQ.nextval id FROM DUAL </selectKey> INSERT INTO POJO ( ID,COL1,COL2,COL3,COL4,COL5,COL6) VALUES (#{id,jdbcType=INTEGER}, #{col1,jdbcType=INTEGER}, #{col2,jdbcType=VARCHAR}, #{col3,jdbcType=INTEGER}, #{col4,jdbcType=INTEGER}, #{col5,jdbcType=DATE}, #{col6,jdbcType=INTEGER}) </insert>
注:<selectKey>標(biāo)簽中加入order='BEFORE'即可在插入完成后返回主鍵。
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。