Oracle条件判断之IF ELSE的使用方式
更新时间:2025年06月09日 10:37:07 作者:雷神乐乐
这篇文章主要介绍了Oracle条件判断之IF ELSE的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
Oracle条件判断之IF ELSE
1.条件判断语法
IF 条件1 THEN 执行的逻辑1; ELSIF 条件2 THEN --条件1不满足的时候,会先判断是否满足条件2 执行的逻辑2; ELSE ---条件1 和条件2 都不满足 执行的逻辑3; END IF; ---结束 IF ELSE 条件判断
2.练习1
传入一个员工的编号
如果这个员工的工资小于1000,就给他加300奖金
如果这个员工的工资 1000 到 2000,就给他加200奖金
如果这个员工的工资 大于 2000,就给他加100奖金
select * from emp where empno=7788;

DECLARE
v_EMPNO number := &input;
v_SAL number;
BEGIN
select sal into v_SAL from emp where empno = v_EMPNO;
IF v_SAL < 1000 THEN
UPDATE emp set comm = nvl(comm, 0) + 300 where empno = v_EMPNO;
-- commit;
ELSIF v_SAL between 1000 and 2000 THEN
--条件1不满足的时候,会先判断是否满足条件2
UPDATE emp set comm = nvl(comm, 0) + 200 where empno = v_EMPNO;
-- commit;
ELSE
---条件1 和条件2 都不满足
UPDATE emp set comm = nvl(comm, 0) + 100 where empno = v_EMPNO;
END IF; ---结束 IF ELSE 条件判断
-- commit;
END;
select * from emp where empno=7788;
3.练习2
示例:用户输入 员工编号,判断 这个员工所在部门的人数,如果3个以内,则不变,如果5个以内 则 该部门所有员工降薪100,否则 所有员工降薪200
DECLARE
v_EMPNO EMP.EMPNO%TYPE := &input;
v_COUNT number;
BEGIN
select count(1)
into v_COUNT
from emp
WHERE DEPTNO IN (SELECT DEPTNO FROM EMP WHERE EMPNO = V_EMPNO);
IF v_COUNT < 3 THEN
NULL;
ELSIF v_COUNT >= 3 and v_COUNT < 5 THEN
UPDATE emp
set sal = sal - 100
where DEPTNO IN (SELECT DEPTNO FROM EMP WHERE EMPNO = V_EMPNO);
-- commit;
ELSE
UPDATE emp
set sal = sal - 200
where DEPTNO IN (SELECT DEPTNO FROM EMP WHERE EMPNO = V_EMPNO);
END IF;
-- commit;
END;总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
oracle中left join和right join的区别浅谈
oracle中left join和right join的区别浅谈,需要的朋友可以参考一下2013-02-02
Oracle数据库ORA-28040:没有匹配的验证协议解决办法
这篇文章主要给大家介绍了关于Oracle数据库ORA-28040:没有匹配的验证协议问题的解决办法,ORA-28040是Oracle数据库的错误代码,表示没有匹配的验证协议,这通常是由于客户端和服务器之间的身份验证协议不匹配导致的,需要的朋友可以参考下2024-03-03


最新评论