oracle的高阶使用【4】序列和触发器

本文介绍了Oracle数据库中序列的使用,强调其在主键自增中的角色,以及触发器的原理。通过示例展示了如何创建和操作序列,以及触发器在监听数据库操作时的用法。同时,探讨了如何结合触发器实现主键的隐式自增。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

oracle当中序列是一组连续且不重复的值,一般用于主键的自增。
触发器是一个特殊的程序,当触发某个事件时会自动执行,用户不能直接调用,主要用于对数据库的特定操作或系统事件进行监听并响应。

1、系统、软件和约束条件

  • win10
  • oracle11g
  • sql developer

2、序列操作

  • 执行以下操作:
# 创建一个序列,从1开始,每次增加1
create sequence myseq  increment  by 1 start with 1;
# 查询一次序列,自增1
select myseq.nextval from dual;
# 获得当前序列的值
select myseq.currval from dual;
# 删除序列
drop sequence myseq;

3、触发器操作

  • 1 请牢记下面new/old的对应关系
        insert    delete      update
:new    有效      无效         有效
:old    无效      有效         有效
  • 1 创建一个触发器,监听emp表的delete操作
drop trigger tr1;--创建触发器之前先删除,确保创建成功
--创建一个触发器:emp的某一行被删除之后,该触发器被触发
create trigger tr1
  after delete on emp
  for each row
begin
  --触发器被触发之后执行的操作,:OLD代表被删除的数据
  dbms_output.put_line('emp表中'||:OLD.empno||'数据被人删了');
end;
  • 2 创建一个触发器,监听emp表的insert操作
drop trigger tr2; --创建触发器之前先删除,确保创建成功
--创建一个触发器:emp新增一行之后,该触发器被触发
create trigger tr2
  before insert on emp
  for each row
begin
  --触发器被触发之后执行的操作,:NEW代表被新增的数据
  dbms_output.put_line('emp表中新增了'||:NEW.empno);
end;

4、结合触发器和序列,完成主键自增

  • 1 显式调用序列
# 创建一个序列
drop sequence myseq1;
create sequence myseq1  increment  by 1 start with 1;
# 创建一张表
drop table t_user;
create table t_user(id int primary key,name varchar(20));
# 使用序列插入记录
insert into t_user(id,name) values(myseq1.nextval,'ali');
insert into t_user(id,name) values(myseq1.nextval,'xiaoli');

以上的方式必须显式调用序列,只能是:
insert into t_user(id,name) values(myseq1.nextval,'xiaoli');
不能是:
insert into t_user(name) values('xiaoli');
所以,我们还需要了解隐式自增。

  • 2 结合触发器调用序列
# 创建一个序列
drop sequence myseq1;
create sequence myseq1  increment  by 1 start with 1;
# 创建一张表
drop table t_user;
create table t_user(id int primary key,name varchar(20));
# 创建一个触发器
drop trigger tr1;
create trigger tr1
  before insert on t_user for each row
begin
    select myseq1.nextval into :new.id from dual;
end;
# 插入数据
insert into t_user(name) values('ali');
insert into t_user(id,name) values(8,'ali');--此处的8会被替换掉为序列的值

以上就是序列、触发器以及它们的配合使用。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值