如何让布尔变量在过程,函数,触发器以及匿名块中发挥作用

本文介绍在Oracle数据库中如何使用PL/SQL的布尔类型进行条件判断,包括在函数和触发器中的具体实现方法。通过实例展示了如何创建自定义的布尔函数来检查特定条件,并在触发器中利用这些函数来控制数据操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在oracle中,布尔类型BOOLEAN是不允许在SQL中出现的,但是可以在PL/SQL中定义并使用。

--1)在匿名块中的使用    

CREATE OR REPLACE FUNCTION vaild_emp(emp_no number)

--判断某个雇员号是否在EMP表中存在,若存在则返回TRUE,不存在则返回FALSE

RETURN BOOLEAN--注意函数的返回类型为布尔类型。

AS
v_temp INT;
BEGIN
  SELECT 1 INTO v_temp FROM emp WHERE empno=emp_no;
  RETURN TRUE;
  EXCEPTION 
    WHEN NO_DATA_FOUND THEN
      RETURN FALSE;
      END;
-----------------------------------这个函数就相当于定义了你自己要使用的布尔变量      
  
DECLARE
      v_ret BOOLEAN;
      BEGIN
        v_ret := vaild_emp(7369);---7369调用刚定义的函数传递的实参
        if v_ret then
          dbms_output.put_line('true');
          else
            dbms_output.put_line('false');
            end if;
            end;

--2)在触发器中使用

CREATE OR REPLACE FUNCTION vaild_stuno(v_stuno NUMBER)
--说明:该函数用于当想要删除 入党申请书递交详情中的记录的时候,先到上党校情况中去查看是否有该同学的记录
--若有,则返回true,若无,则返回false;
RETURN BOOLEAN
AS
v_temp NUMBER;
BEGIN
  SELECT 1 INTO v_temp FROM  上党校情况 WHERE stu_no=v_stuno;
  RETURN TRUE;
  EXCEPTION
    WHEN NO_DATA_FOUND THEN
      RETURN FALSE;
      END;

CREATE OR REPLACE TRIGGER PAR_CLA_INFO_BETRI
BEFORE DELETE ON 入党申请书递交详情
FOR EACH ROW
  DECLARE
  v_ret BOOLEAN;
  BEGIN
    v_ret:=vaild_stuno(:old.stu_no);--:OLD.STU_NO为删除前的学生的学号,为传递给函数VAILD_STUNO的实参
    IF v_ret THEN
      raise_application_error(-20002,'不允许删除该同学的记录。请先删除该流程之后的所有流程中,该同学的记录!');
      ELSE
        UPDATE youth_league_branch SET sub_no='0' WHERE stu_no=:OLD.stu_no;
        END IF;
        END;
            

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值