mybatis怎样批量插入数据到oracle,就算id自动增长问题

2025-05-16 06:22:39
推荐回答(2个)
回答1:

需要在oracle中建立一个队列 代码如下:
create sequence SEQ_ID
minvalue 1
maxvalue 999999999
start with 0
increment by 1
cache 20;
查询下一个序列值就用 select SEQ_ID.Nextval from dual
查询当前序列值就用 select SEQ_ID.CURRVAL from dual
在insert中例子如下:
insert into tab_name(id)values(SEQ_ID.nextval);就可以了 当然 你也可以用lpad函数使id的位数一样 例如 lpad(SEQ_ID.nextval,10,'0');
~如果你认可我的回答,请及时点击【采纳为满意回答】按钮
~~手机提问的朋友在客户端右上角评价点【满意】即可。

回答2:

Oracle数据库中有一个可以自动增长的序列Sequences,在这里你可以建立对哪张表实现自动增长,调用方式:名称+.nextval,例如你的sequence名称是seq_test,调用就用seq_test.nextval,至于你说的批量插入,可以根据自己的需求来操作,如果是前台传来的值,可以通过for循环等
希望对你有帮助