欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

oracle設置mybatis自動生成id插入方式

 更新時間:2023年07月29日 14:17:52   作者:愛麗絲和她的巫師帽  
這篇文章主要介紹了oracle設置mybatis自動生成id插入方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

oracle設置mybatis自動生成id插入

本來想要在插入時自動生成id是很簡單的,就是用mybatisPlus的注解,在實體類的id字段上加上@TableId注解,自動生成由雪花算法生成的id,不但隨機,而且自增,非常好用

但是現(xiàn)在接手了一個項目沒有導入mybaitisPlus,只有mybatis,我不敢亂加東西,只能用mybatis做主鍵自增了

首先這是一個oracle數(shù)據(jù)庫,和mysql不同,Oracle不能設置自增,只能先創(chuàng)建一個序列(sequence),然后在插入數(shù)據(jù)時引用該序列的值,

原sql如下:

insert into table_name (ID, name, sex)  
values (sequence_name.NEXTVAL,'張三','男')  

我們從頭開始,在創(chuàng)建序列之前,先查詢一下已有序列

SELECT * from user_sequences

創(chuàng)建序列

CREATE sequence sequence_name
increment by 1 //以1倍的速度增長,你也可以設置其他數(shù)字
start with 1    //從id=1開始增長  
 maxvalue 9999  //最大值為9999,根據(jù)情況  
 minvalue 1     //最小值1  
 nocycle        //不循環(huán),也就是一直增長         
 cache 20       //設置緩存cache個序列,如果系統(tǒng)down掉了或者其它情況將會導致序列不連續(xù),也可以設置為---------NOCACHE  
noorder;

mybatis中代碼

<insert id="insertAccessLog" parameterType="com.example.AccessLog">
        <selectKey keyProperty="id" resultType="java.lang.Integer" order="BEFORE">
            SELECT YOUR_SEQUENCE_NAME.NEXTVAL FROM DUAL
        </selectKey>
        INSERT INTO your_table_name (ID, name,sex)
        VALUES (#{id}, #{name}, #{sex})
    </insert>

selectKey標簽可以在插入語句執(zhí)行前執(zhí)行一個查詢,以生成主鍵值。

selectKey標簽的常用屬性:

  • keyProperty:指定一個Java對象的屬性,用于接收生成的主鍵值。生成的主鍵值將被設置到該屬性中。
  • keyColumn:指定數(shù)據(jù)庫表中的列名,用于接收生成的主鍵值。生成的主鍵值將被設置到該列中。
  • resultType:指定生成的主鍵值的數(shù)據(jù)類型??梢允荍ava中的任何原生類型,如intlong,或者是一個包裝類型,如Integer、Long。
  • order:指定selectKey標簽的執(zhí)行順序。可以選擇在插入語句執(zhí)行前執(zhí)行(BEFORE)或執(zhí)行后執(zhí)行(AFTER)。默認值是AFTER。

注意:java實體類屬性的類型和數(shù)據(jù)庫字段類型最好一致,否則在插入時會導致插入時類型不匹配

還有一種更簡單的寫法

INSERT INTO your_table_name (ID, name,sex)
        VALUES (your_sequence_name, #{name}, #{sex})

下面還有一種情況要注意

mybatis插入一個list,list里是實體類,實體類本身沒有生成id,需要oracle數(shù)據(jù)庫使用sequence生成id,如插入List<userDTO>

本來我們使用foreach標簽配合values的寫法批量插入的,

如下:

insert into PERMANENT_ACCESS_USER (EMPLOYEE_USERACCOUNT,EMPLOYEE_NAME)
            values 
<foreach collection="list" item="item" separator="," close=";">
(#{item.userAccounts},#{item.empName})
</foreach>

或者這樣

insert all
        <foreach collection="list" item="item" separator=" ">
            into table_name (name,sex) values ( #{item.name},#{item.sex})
        </foreach>
        SELECT * FROM DUAL

但是現(xiàn)在有個問題,在一個values中只能調(diào)用一次NEXTVAL,使得我們沒辦法在批量插入時給ID賦不同的值

所以現(xiàn)在解決辦法是使用觸發(fā)器,在插入時將序列值賦給id,但是這樣的話就需要每張表都要建一個觸發(fā)器,而觸發(fā)器又不可控,但是現(xiàn)在又沒有找到另外的方法,只能先這樣,

具體參考:Oracle sql批量插入多條數(shù)據(jù)

或者干脆不用序列,直接生成一個隨機數(shù),用隨機數(shù)當id

注意!??!因為用了inser into。。。select的語法,所以useGeneratedKeys="false"這個一定要加在insert標簽里面,否則會報錯

這個坑踩了好久,一度誤以為mybatis不支持inser into。。。select語法,一定要注意

useGeneratedKeys="false"
<insert id="insertPermanentUser" parameterType="list" useGeneratedKeys="false">
        INSERT INTO PERMANENT_ACCESS_USER(id, name, sex)
        SELECT id, name, sex FROM
        <foreach collection="list" item="item" separator=" union all " open="(" close=")">
            SELECT dbms_random.VALUE(0,10000000) as id,#{item.name} as name,#{item.sex} as sex from dual
        </foreach>
    </insert>

oracle中自動生成id的函數(shù)以及注意事項

Oracle中自動生成id的函數(shù) :sys_guid()

SELECT sys_guid() FROM aTable a ;

注意:上面這個是可以自動生成id,但是很多時候自動生成的id會出現(xiàn)亂碼

原因:SYS_GUID 以16位RAW類型值形式返回一個全局唯一的標識符,而我們一般用的是十六進制的字符

所有用以下的解決方式:

-- 用大寫或者小寫函數(shù)都能解決 : 因為大小寫會把raw串自動轉(zhuǎn)換為十六進制
select lower(sys_guid()) from aTable a;
-- 或者?
select upper(sys_guid()) from aTable a;
-- 個人推薦這種:因為它不把值轉(zhuǎn)換成大小寫
-- rawtohex函數(shù): 將raw串轉(zhuǎn)換為十六進制
select rawtohex(sys_guid()) from aTable a;
-- 還有
select lower(rawtohex(sys_guid())) from aTable a;

總結

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

最新評論