教你如何通过PL/SQL创建序列和触发器实现表自增字段

 更新时间:2022年11月24日 10:02:15   作者:ZenPower  
本文给大家分享如何通过PL/SQL创建序列和触发器实现表自增字段,需要注意的是,在数据库操作中,触发器的使用对系统资源耗费相对较大,考虑到大表操作的性能问题, 我们尽可能的减少触发器的使用,改为直接手动调用序列函数即可

假设我们有一个address表,希望实现地址编号address_id的自增

1.通过PL/SQL创建序列:

首先,新建Sequences对象

选择序列所有者,并填写序列的起始值、名称和增量等信息,并应用

可以查看其SQL创建语句

-- Create sequence 
create sequence SEQ_ADDRESS_ID
minvalue 10001
maxvalue 999999999999999999999999999
start with 10001
increment by 1
cache 20;

序列创建完成后,可以通过系统表dual查询

--查询序列当前值
select seq_address_id.currval from dual;
--查询序列下一值
select seq_address_id.nextval from dual;

注:Oracle刚创建完序列后用currval查询不了当前值的,得先用nextval查询过后才能进行currval的查询

到此,已经可以实现address表中地址编号字段address_id的自增,通过插入时调用序列的nextval即可

insert into address(address_id,address_name) values(seq_address_id.nextval,'第八大街');

为了使序列的调用方式更加方便,我们接下来要创建一个触发器。

2.通过PL/SQL创建触发器

首先,新建trigger对象

填写触发器名称,以及下列要素并确定

触发时间(Fires):before、after、instead of
事件(Event):insert、update、delete
表或视图(Table or View):选择需要创建触发器的表

确定后,会打开触发器程序编辑窗口,我们需要在红框处编写触发器要执行的SQL语句

这里就是为address表的address_id字段插入自增序列:

select seq_address_id.nextval into :new.address_id from dual;

该触发器在数据库注册了表的侦听,即当指定表address插入记录之前,我们调用序列的nextval获得新值,插入需要自增的字段。 

至此,我们就完成了address表的address_id字段自增,执行插入SQL时,该字段会自动增长

insert into address(address_name) values('第八大街');

需要注意的是,在数据库操作中,触发器的使用对系统资源耗费相对较大。对于容量相对较小的表我们可以忽略触发器带来的性能影响。考虑到大表操作的性能问题, 我们尽可能的减少触发器的使用,改为直接手动调用序列函数即可。

到此这篇关于教你如何通过PL/SQL创建序列和触发器实现表自增字段的文章就介绍到这了,更多相关PL/SQL创建序列和触发器实现表自增字段内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • oracle中修改表名的几种方式

    oracle中修改表名的几种方式

    这篇文章主要介绍了oracle中修改表名的几种方式,需要的朋友可以参考下
    2014-07-07
  • oracle查询截至到当前日期月份所在年份的所有月份

    oracle查询截至到当前日期月份所在年份的所有月份

    这篇文章主要介绍了oracle查询截至到当前日期月份所在年份的所有月份,本文通过代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-07-07
  • 关于expdp任务异常的处理案例详析

    关于expdp任务异常的处理案例详析

    这篇文章主要给大家介绍了关于expdp任务异常处理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • Oracle 数据库连接查询SQL语句

    Oracle 数据库连接查询SQL语句

    oracle 连接查询分如下几种方法,大家可以看看,整理了下oracle 内外链接。
    2009-08-08
  • Oracle提高sql执行效率的心得建议

    Oracle提高sql执行效率的心得建议

    sql执行效率一直都是为人所关注,那到底应该怎样提高呢?有什么比较好的方法,下面与大家分享下比较不错的建议,感兴趣的朋友可以参考下,希望对大家有所帮助
    2013-08-08
  • ORACLE中常用的几种正则表达式小结

    ORACLE中常用的几种正则表达式小结

    相信大家对正则表达式都不陌生,从linux下的命令到Java等编程语言,正则表达式无处不在,下面这篇文章主要给大家介绍了关于ORACLE中常用的几种正则表达式的相关资料,需要的朋友可以参考下
    2022-09-09
  • Oracle 创建用户及数据表的方法

    Oracle 创建用户及数据表的方法

    刚开始学习oracle的朋友可以看下,这个是基础了。
    2009-09-09
  • oracle设置密码复杂度及设置超时退出的功能

    oracle设置密码复杂度及设置超时退出的功能

    我们都知道密码策略加固的参数一般包括密码长度、复杂度检测、最大最小使用时间、过期警报时间、最大登录失败次数以及锁定时间等设置,下面这篇文章主要给大家介绍了关于oracle设置密码复杂度及设置超时退出功能的相关资料,需要的朋友可以参考下
    2022-06-06
  • oracle使用存储过程将表数据以excel格式导出的操作方法

    oracle使用存储过程将表数据以excel格式导出的操作方法

    虽然目前pl/sql developer等数据库客户端软件都支持将表数据以excel格式导出,但是如果数据量大,需要等客户端加载表数据等待很久,这篇文章给大家分享oracle使用存储过程将表数据以excel格式导出的操作方法,需要的朋友可以参考下
    2024-07-07
  • oracle自动巡检脚本生成html报告的方法

    oracle自动巡检脚本生成html报告的方法

    这篇文章主要介绍了oracle自动巡检脚本生成html报告的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12

最新评论