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;
经验分享 程序员 微信小程序 职场和发展