一:触发器
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;