Oracle条件判断——IF ELSE的使用

目录

1.条件判断语法

2.练习1

3.练习2


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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雷神乐乐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值