02.两个经典的Oracle触发器示例
来源:互联网 发布:淘宝卖会员账号 编辑:程序博客网 时间:2024/06/04 20:13
【案例一】
题目:
--触发器:
--添加员工信息,流水号作为自动编号(通过序列生成),
--并且判断如果工资小于0,则改为0;如果大于10000,则改为10000。
CREATE TABLE emp2(
e_id NUMBER,
e_no NUMBER,
e_name VARCHAR2(20),
e_sal NUMBER
)
SELECT * FROM emp2;
CREATE SEQUENCE seq_trg_id;
INSERT INTO emp2(e_id,e_no,e_name,e_sal) VALUES(seq_trg_id.nextval,7788,'章子',
1000000000000)
INSERT INTO emp2(e_id,e_no,e_name,e_sal) VALUES(seq_trg_id.nextval,7788,'章子怡',-10)
CREATE OR REPLACE TRIGGER trg_add_emp_info
BEFORE INSERT
ON emp2
FOR EACH ROW
DECLARE
-- local variables here
BEGIN
SELECT seq_trg_id.NEXTVAL INTO :NEW.e_id FROM dual;
IF :NEW.e_sal < 0 THEN
:NEW.e_sal := 0;
ELSIF :NEW.e_sal > 10000 THEN
:NEW.e_sal := 10000;
END IF;
END;
【 案例二】
题目:
--扩充练习:
--为emp建立触发器,将删除的记录放到emp3表中(autoid,deptno,empno,ename,del_rq-删除日期)
--测试代码
CREATE TABLE emp3(
autoid NUMBER PRIMARY KEY,
deptno NUMBER,
empno NUMBER,
ename VARCHAR2(20),
del_rq DATE
)
CREATE SEQUENCE seq_trg_del_autoid;
INSERT INTO emp
(empno, ename, deptno)
VALUES
(114, '阿娇', 10);
COMMIT;
SELECT * FROM emp;
DELETE emp WHERE empno = 114;
SELECT * FROM emp3;
答案:
CREATE OR REPLACE TRIGGER trg_del_emp_info
BEFORE DELETE
ON emp
FOR EACH ROW
DECLARE
-- local variables here
BEGIN
INSERT INTO emp3(autoid,deptno,empno,ename,del_rq)
VALUES(seq_trg_del_autoid.NEXTVAL,:OLD.deptno,:OLD.empno,:OLD.ename,sysdate);
END;
- 02.两个经典的Oracle触发器示例
- 两个经典的Oracle触发器示例
- 两个经典的Oracle触发器示例
- 两个经典的Oracle触发器示例
- 两个经典的Oracle触发器示例
- 两个经典的Oracle触发器示例 .
- 两个经典的Oracle触发器示例
- 两个经典的Oracle触发器示例
- 一个完整的Oracle触发器示例
- oracle 触发器两个重要的内存表
- 关于oracle触发器的两个小例子
- Oracle触发器简单示例
- oracle触发器示例
- Oracle触发器示例
- oracle触发器示例
- Oracle 触发器实例(含Oracle游标的示例)
- Oracle触发器 同一事件激活两个触发器
- Oracle数据库简单触发器示例
- Jquery实现无限级树状结构并动态添加增删改等编辑功能
- CodeForces 796A Buying A House
- C++中break、continue、return的区别
- Scala中的下划线到底有多少种应用场景?
- Spring学习-19:Spring的AOP:带有切点的切面
- 02.两个经典的Oracle触发器示例
- 论文笔记:Histopathological Image Classification Using Discriminative Feature-Oriented Dictionary Learnin
- 键盘事件
- 基于Python selenium2的测试环境的搭建与安装
- 获得echarts饼图需要的series中的data格式
- JavaScript 第一讲 基本代码框架
- linux使用记录
- GSM 接收机实验
- smashing the stack for fun and profit 译文