oracle 快速入门之第六章 触发器&内置程序包
一:触发器
1.触发器的关键词:trigger 2.概述:是一个特殊的存储过程,而存储过程又是一个特殊的函数 当执行DML(数据操纵语言)语句时,触发器就会自动触发并且自动执行,而不是像函数那样需要手动调用。 3.触发器的语法:
create or replace trigger t_name before|after insert|delete|update on table|view for each row begin 触发器的操作 end;
4.语法解释--------2322数字
2个时间点 before 在新增或者修改或者删除操作执行前被触发 after 在新增或者修改或者删除操作执行后被触发 3个特定事件 insert|delete|update 2个触发操作: 行级触发器 语句级触发器 2个触发属性 :old :new
案例:创建一个触发器,作用:欧阳俊雄不能开除
create or replace trigger t_oydel
after
delete
on stuInfo
for each row
begin
--利用:old对象去调用老表中已经存在的字段做判断
if :old.stuName = 欧阳俊雄 then --状态码的范围:-20000 - -20099
--错误提示 raise_application_error(状态码,错误内容提示);
raise_application_error(-20001,级别不够,无法删除);
end if;
end;
delete from stuInfo where stuName = 欧阳俊雄
案例:创建一个触发器,作用:李白不能加入本表
create or replace trigger t_yr
after
insert
on stuInfo
for each row
begin
if :new.stuName = 李白 then
raise_application_error(-20002,黑户,不能加入公司);
end if;
end;
案例:创建一个触发器,作用:不能修改张秋丽的信息
create or replace trigger t_zql
after
update
on stuInfo
for each row
begin
if :old.stuName = 张秋丽 then
raise_application_error(-20003,张秋丽不能修改);
end if;
end;
注意:一个触发器同时触发多个事件
案例:张秋丽不能修改,欧阳俊雄不能删除,刘邦不能新增
create or replace trigger t_demo
after
insert or update or delete
on stuInfo
for each row
begin
if updating then
if :old.stuName = 张秋丽 then
raise_application_error(-20001,张秋丽不能修改);
end if;
elsif deleting then
if :old.stuName = 欧阳俊雄 then
raise_application_error(-20002,欧阳俊雄不能删除);
end if;
elsif inserting then
if :new.stuName = 刘邦 then
raise_application_error(-20003,刘邦不能增加);
end if;
end if;
end;
模拟标识列的实现(序列+触发器)
实现标识列的步骤:
1.创建序列
2.创建触发器即可
1.创建序列
create sequence s_empno;
2.创建一个触发器
create or replace trigger t_emp_no
before
insert
on demo_demp
for each row
begin
--oracle 10g
--赋值:查询序列的下一个值赋值给当前demo_demp表中的新增的数据的字段
--select s_empno.nextval into :new.empno from dual;
--oracle 11g
:new.empno:=s_empno.nextval;
end;
二:内置程序包
1.基本概念:
-
扩展数据库的功能 为 PL/SQL 提供对 SQL 功能的访问 用户 SYS 拥有所有程序包 是公有同义词 可以由任何用户访问
2.常用的内置程序包
STANDARD和DBMS_STANDARD 定义和扩展PL/SQL语言环境 DBMS_LOB 提供对 LOB数据类型进行操作的功能 DBMS_OUTPUT 处理PL/SQL块和子程序输出调试信息 DBMS_RANDOM 提供随机数生成器 DBMS_SQL 允许用户使用动态 SQL DBMS_XMLDOM 用DOM模型读写XML类型的数据 DBMS_XMLPARSER XML解析,处理XML文档内容和结构 DBMS_XMLQUERY 提供将数据转换为 XML 类型的功能 DBMS_XSLPROCESSOR 提供XSLT功能,转换XML文档 UTL_FILE 用 PL/SQL 程序来读写操作系统文本文件
案例:演示九九乘法表
begin
for i in 1..9 loop
for j in 1..i loop
--不跨行System.out.print();
dbms_output.put(j || * || i || = || ( i * j ) || );
end loop;
dbms_output.new_line();--跨行System.out.println();
end loop;
end;
下一篇:
Mysql安装流程 【压缩版】
