oracle 快速入门之第六章 触发器&内置程序包

一:触发器

1.触发器的关键词:trigger
2.概述:是一个特殊的存储过程,而存储过程又是一个特殊的函数
当执行DML(数据操纵语言)语句时,触发器就会自动触发并且自动执行,而不是像函数那样需要手动调用。
3.触发器的语法

  1. create or replace trigger t_name
  2. before|after
  3. insert|delete|update
  4. on table|view
  5. for each row
  6.  begin
  7.  触发器的操作
  8.  end;

4.语法解释--------2322数字

  • 2个时间点   
  1. before  在新增或者修改或者删除操作执行前被触发
  2. after   在新增或者修改或者删除操作执行后被触发
  • 3个特定事件
  1. insert|delete|update

  • 2个触发操作:
  1. 行级触发器

  2. 语句级触发器

  • 2个触发属性
  1. :old

  2. :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.常用的内置程序包

  1. STANDARD和DBMS_STANDARD
  2. 定义和扩展PL/SQL语言环境
  3. DBMS_LOB
  4. 提供对 LOB数据类型进行操作的功能
  5. DBMS_OUTPUT
  6. 处理PL/SQL块和子程序输出调试信息
  7. DBMS_RANDOM
  8. 提供随机数生成器
  9. DBMS_SQL
  10. 允许用户使用动态 SQL
  11. DBMS_XMLDOM
  12. 用DOM模型读写XML类型的数据
  13. DBMS_XMLPARSER
  14. XML解析,处理XML文档内容和结构
  15. DBMS_XMLQUERY
  16. 提供将数据转换为 XML 类型的功能
  17. DBMS_XSLPROCESSOR
  18. 提供XSLT功能,转换XML文档
  19. UTL_FILE
  20. 用 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;

你可能感兴趣的:(数据库,database,oracle,sql,数据库架构)