王朝网络
分享
 
 
 

Oracle触发器

王朝学院·作者佚名  2010-01-02  
宽屏版  字体: |||超大  

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

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

on a.deptno = b.deptno

select * from myview

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;

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/hzz1988/archive/2009/12/30/5107869.aspx

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有