Oracle触发器

触发器是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,下文中就为大家详细讲解Oracle触发器。

创建触发器(行级触发器)

create or replace trigger tri_update_emp_bak

 

after update

 

on emp_bak

 

for each row 每更新一行 就触发一次

 

begin

 

Oracle 里面 对触发器 也提供了特殊的对象 :NEW :OLD 来访问 更新前后的数据

 

dbms_output.put_line(‘更新后’ || :NEW.sal);

 

dbms_output.put_line(‘更新前’ || :OLD.sal);

 

if updating then

 

end if;

 

if inserting

 

end;

 

创建触发器(行级触发器)(前置)

 

create or replace trigger tri3_update_emp_bak

 

before update

 

on emp_bak

 

for each row 每更新一行 就触发一次

 

begin

 

oracle 里面 对触发器 也提供了特殊的对象 :NEW :OLD 来访问 更新前后的数据

 

dbms_output.put_line(‘更新后’ || :NEW.sal);

 

dbms_output.put_line(‘更新前’ || :OLD.sal);

 

end;

 

select * from emp_bak

 

update emp_bak set sal = 1000 where empno in (7788)

 

创建触发器(表级触发器)

 

//表级别触发器里面 不允许使用 :NEW :OLD 变量

 

create or replace trigger tri2_update_emp_bak

 

after update

 

on emp_bak

 

begin

 

dbms_output.put_line(‘更新后’ || :NEW.sal);

 

dbms_output.put_line(‘更新前’ || :OLD.sal);

 

end;

 

创建触发器(行级触发器)

 

create or replace trigger tri4_update_emp_bak

 

after update of sal

 

on emp_bak

 

for each row 每更新一行 就触发一次

 

begin

 

oracle 里面 对触发器 也提供了特殊的对象 :NEW :OLD 来访问 更新前后的数据

 

dbms_output.put_line(‘更新后’ || :NEW.sal);

 

dbms_output.put_line(‘更新前’ || :OLD.sal);

 

end;

 

create table userinfo

 

(

 

userid number(4) PRimary key,

 

username varchar2(20)

 

)

 

create table addrinfo

 

(

 

addrid number(4) primary key,

 

addname varchar2(20),

 

userid number(4) references userinfo(userid)

 

)

 

insert into userinfo values (1,’李四’)

 

insert into addrinfo values (1,’湖北武汉’,1)

 

select * from addrinfo

 

delete from userinfo where userid =1

 

级联删除

 

create or replace trigger tri_userinfo_delete

 

before delete

 

on userinfo

 

for each row

 

begin

 

delete from addrinfo where userid = :OLD.userid;

 

insert into

 

end;

 

create table dept_bak as select * from dept

 

create or replace view myview

 

as

 

select a.empno,a.ename,a.sal,b.dname

 

from emp a inner join dept b

 

update myview set sal = 1000,dname=’aaaaa’ where empno = 7499

 

替代触发器 用在视图上面 只能是行级的

 

替代触发器 特点是 真正的操作已经 变成了一个动作而已 功能由触发器来完成

 

create or replace trigger tri_myview

 

instead of update

 

on myview

 

begin

 

dbms_output.put_line(‘删除操作执行了。。。’);

 

update emp set sal = :NEW.sal where empno = :OLD.empno;

 

update dept set dname = :NEW.dname where dname = :OLD.dname;

 

delete from emp where empno = :OLD.empno;

 

end;

 

select * from emp;

 

select * from dept;

 

update emp_bak set ename =’aaaa’,sal = 10000 where empno in (7788)

 

系统包

 

产生随机数

 

**** **** **** ****

 

dbms_random.value 0-1 之间的随机小数

 

dbms_random.random 随机整数

 

select dbms_random.value from dual;

 

create or replace procedure proc_cardno(mycardno out varchar2)

 

as

 

tempcard varchar2(50);

 

cardno varchar2(19);

 

begin

 

tempcard:= dbms_random.value;

 

cardno:=substr(tempcard,2,4)||’ ‘||substr(tempcard,6,4)||’ ‘||substr(tempcard,10,4)||’ ‘||substr(tempcard,14,4);

 

mycardno:=cardno;

 

dbms_output.put_line(tempcard);

 

dbms_output.put_line(cardno);

 

end;

 

使用UTL_FILE包读写文件

 

create directory MY_DIR as ‘d:\temp’;

 

create directory MY_DIR2 as ‘d:\temp2’;

 

declare

 

定义文件对象

 

myfile utl_file.file_type;

 

定义变量 用来存储每读出一行的数据

 

linestr varchar2(200);

 

begin

 

打开文件

 

myfile:= utl_file.fopen(‘MY_DIR’,’oracle.log’,’r’);

 

进行读取(循环)

 

loop

 

utl_file.get_line(myfile,linestr);

 

dbms_output.put_line(linestr);

 

end loop;

 

exception

 

when others then

 

utl_file.fclose(myfile);

 

dbms_output.put_line(‘读取完毕!’);

 

end;

 

declare

 

定义文件对象

 

myfile utl_file.file_type;

 

定义变量 用来存储每读出一行的数据

 

linestr varchar2(200);

 

begin

 

打开文件

 

myfile:= utl_file.fopen(‘MY_DIR’,’oracle.log’,’a’);

 

追加数据

 

utl_file.get_line(myfile,linestr);

 

utl_file.put_line(myfile,’你好,这是新的数据’,true);

 

utl_file.fclose(myfile);

 

exception

 

when others then

 

utl_file.fclose(myfile);

 

dbms_output.put_line(‘读取完毕!’);

 

end;

 

拷贝

 

declare

 

定义文件对象

 

sourcefile utl_file.file_type;

 

targetfile utl_file.file_type;

 

定义变量 用来存储每读出一行的数据

 

linestr varchar2(200);

 

begin

 

打开文件

 

sourcefile:= utl_file.fopen(‘MY_DIR’,’oracle.log’,’r’);

 

targetfile:= utl_file.fopen(‘MY_DIR2′,’copy.txt’,’a’);

 

进行读取(循环) 并且写入到新的文件里面

 

loop

 

utl_file.get_line(sourcefile,linestr);

 

utl_file.put_line(targetfile,linestr,true);

 

dbms_output.put_line(linestr);

 

end loop;

 

exception

 

when others then

 

utl_file.fclose(sourcefile);

 

utl_file.fclose(targetfile);

 

dbms_output.put_line(‘拷贝完毕!’);

 

end;

关于Oracle触发器的问题就为大家讲解到这里,还有很多Oracle触发器的知识这里没有涉及到,以后我还会继续为大家讲解更多的关于Oracle触发器的知识点,希望对大家能够有所帮助。

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/283526.html<

(0)
运维的头像运维
上一篇2025-05-13 23:31
下一篇 2025-05-13 23:32

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注