Oracle插入数据时获取自增ID.docx

上传人:牧羊曲112 文档编号:3162518 上传时间:2023-03-11 格式:DOCX 页数:2 大小:36.84KB
返回 下载 相关 举报
Oracle插入数据时获取自增ID.docx_第1页
第1页 / 共2页
Oracle插入数据时获取自增ID.docx_第2页
第2页 / 共2页
亲,该文档总共2页,全部预览完了,如果喜欢就下载吧!
资源描述

《Oracle插入数据时获取自增ID.docx》由会员分享,可在线阅读,更多相关《Oracle插入数据时获取自增ID.docx(2页珍藏版)》请在三一办公上搜索。

1、Oracle插入数据时获取自增IDOracle插入数据时获取自增ID自增字段:表atable(id,a) id需要自增 首先建立一个序列:create sequence seq_atable minvalue 1 maxvalue 999999999999999999 start with 1 increment by 1 nocache有二种方式使用自增字段:使用序列+触发器实现自增,插入语句不需要管自增字段如:create or replace trigger trg_atable before insert on atable for each row begin select seq_

2、atable.nextval into :new.id from dual; end;插入数据:insert into atable(a) values(test);注:我创建了sequence 和trigger :,之后在procedure中插入数据,插入的时候没有管ID字段,在应用中,使用了hibernate,虽然hibernate在增加记录的时候也会处理ID,但是添加记录之后,查询记录发现,ID还是根据序列和触发器的规则设置的仅使用序列,需要在插入数据时,自增字段插入序列下一个值如:insert into atable(id,a) values(seq_atable.nextval,test);三、返回刚插入记录的自增字段值如上面的例子,我们插入一条记录后,我想马上返回刚插入的记录的ID号,我该怎么处理呢?首先要解决自增字段的问题,上面的二种方法哪种更适合这种用法呢? 建议使用第二种自增序列,否则处理起这个问题来比较麻烦。使用自增字段的第二种方法,在插入一条记录后马上执行一下下面的语句即返回当前插入数据的ID。$query=select seq_atable.currval from dual;seq_atable.currval 的值只有在同一次会话中,发生seq_atable.nextval后有效:) 所以不会存在取错值的问题。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号