度量快速开发平台-业界最好的全功能软件开发平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 36|回复: 6

[分享] Oracle触发器简单入门记录

[复制链接]

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
发表于 2018-4-25 17:26:34 | 显示全部楼层 |阅读模式
1.触发器实例:
  1. --创建触发器
  2. create or replace trigger test_trigger2
  3. --触发器是在insert或update动作之后执行的
  4. after insert or update
  5. --作用于dms.kqm_leaveapply表的每一行
  6. on dms.kqm_leaveapply
  7. --这里默认为new ,old 怕与其他变量有冲突,则做了修改
  8. referencing new as new_val old as old_val
  9. for each row
  10. --触发器限制条件  
  11. when (new_val.statusname = '核准')
  12. --触发器描述语句中,新数据使用new_val进行引用,在下面的操作语句中,新数据使用:new_val进行引用

  13. declare  --声明变量
  14.    st_str varchar2(100);
  15.    et_str varchar2(100);

  16.    time1 number;
  17.    time2 number;
  18.    ......
  19. begin
  20.    ......

  21.    --查询结果集,进行遍历

  22.    for daylist in (
  23.      --查询出指定时间段内的所有日期
  24.      select to_char(:new_val.startdate+rownum-1,'yyyymmdd') as dd
  25.      from dual
  26.      connect by rownum <=
  27.           trunc(:new_val.enddate - :new_val.startdate)+1
  28.    )
  29.    loop
  30.      
  31.         --写要进行操作的逻辑
  32.         ......
  33.          --更新另外一张表的数据
  34.          update dms.d_dailyreport_t d set d.shours =  (8 - ItemValue)
  35.          where d.personcode = :new_val.workno and  to_char(d.ftime,'yyyy/mm/dd') like to_char(daylist.dd,'yyyy/mm/dd')  ;

  36.    end loop;
  37.   
  38.      --substr()数据截取
  39.      st_str :=substr(:new_val.starttime,1,2) || substr(:new_val.starttime,4,2) ;
  40.      et_str := substr(:new_val.endtime,1,2) || substr(:new_val.endtime,4,2) ;
  41.      time1 := to_number(st_str);
  42.      time2 := to_number(et_str);

  43.      if(Item_m<0) then
  44.          Item_m := Item_m *(-1);
  45.          tHour := tHour -1;
  46.      end if;

  47. end test_trigger2;
复制代码
上面的触发器例子,只是一个框架,并不能执行,这里只做简单的记录,网上的例子有很多,稍微看一下就能简单入门了,这里就不多做记录与说明了~~
回复

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-4-26 17:58:13 | 显示全部楼层
回复 支持 反对

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-4-26 17:59:06 | 显示全部楼层
回复 支持 反对

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-4-26 17:59:37 | 显示全部楼层
回复 支持 反对

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-4-27 14:35:29 | 显示全部楼层
回复 支持 反对

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-4-27 14:36:14 | 显示全部楼层
回复 支持 反对

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-4-27 14:36:59 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2018-5-27 09:26 , Processed in 0.397696 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表