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中误删除表后恢复语句(FLASHBACK)

    oracle中误删除表后恢复语句(FLASHBACK)

    在操作过程中难免会误操作,出现这种情况应该怎样解决呢?不要着急,下面与大家分享下误删的恢复语句
    2013-06-06
  • oracle中left join和right join的区别浅谈

    oracle中left join和right join的区别浅谈

    oracle中left join和right join的区别浅谈,需要的朋友可以参考一下
    2013-02-02
  • oracle 10g 快照操作方法

    oracle 10g 快照操作方法

    本文将详细介绍oracle 10g 快照操作方法包括创建、刷新、修改等,需要了解的朋友可以参考下
    2012-12-12
  • Oracle 数据仓库ETL技术之多表插入语句的示例详解

    Oracle 数据仓库ETL技术之多表插入语句的示例详解

    Oracle 数据库为 ETL 流程提供了丰富的功能,今天我们就给大家介绍一下 Oracle 多表插入语句,也就是 INSERT ALL 语句,今天通过示例代码给大家介绍Oracle 数据仓库 ETL 技术之多表插入语句的相关知识,感兴趣的朋友一起看看吧
    2021-04-04
  • Oracle数据库ORA-28040:没有匹配的验证协议解决办法

    Oracle数据库ORA-28040:没有匹配的验证协议解决办法

    这篇文章主要给大家介绍了关于Oracle数据库ORA-28040:没有匹配的验证协议问题的解决办法,ORA-28040是Oracle数据库的错误代码,表示没有匹配的验证协议,这通常是由于客户端和服务器之间的身份验证协议不匹配导致的,需要的朋友可以参考下
    2024-03-03
  • 在Oracle中导入dmp文件的方法

    在Oracle中导入dmp文件的方法

    这篇文章主要介绍了如何在Oracle中导入dmp文件,很简单,但很实用,需要的朋友可以参考下
    2014-09-09
  • oracle12c安装报错:PRVF-0002的解决方法

    oracle12c安装报错:PRVF-0002的解决方法

    本文为大家介绍下如何解决oracle12c安装报错:PRVF-0002,具体的排查思路如下,有类似情况的朋友可以参考下
    2013-09-09
  • 教你设计大型Oracle数据库

    教你设计大型Oracle数据库

    表及索引的存储容量估算是根据其记录长度及估算的最大记录数确定的。在容量计算中考虑了数据块的头开销及记录和字段的头开销等等。表及索引的initial和next存储参数一般设为相等,pctincrease设为0。
    2009-06-06
  • oracle 数据按主键删除慢问题的解决方法

    oracle 数据按主键删除慢问题的解决方法

    下面小编就为大家带来一篇oracle 数据按主键删除慢问题的解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • oracle 分页问题解决方案

    oracle 分页问题解决方案

    测试说分页查询貌似不起作用,翻到第4页以后,看到的数据结果都是相同的,此等问题应该如何解决,本文将详细介绍
    2012-11-11

最新评论