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安装流程 【压缩版】