04 序列和触发器

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会被替换掉为序列的值

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

posted @ 2020-03-26 20:09  张力的程序园  阅读(243)  评论(0)    收藏  举报