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会被替换掉为序列的值
以上就是序列、触发器以及它们的配合使用。