首页 > 解决方案 > Oracle-APEX 公式中的 ORA-01403

问题描述

我有这个代码。:P99_CAR, :P99_PARTS 是可以选择 ID 的列表(通过查找表), :P99_AMOUNT 是我表单中的一个简单输入。因此,您选择这 3 个部分并想要检查以下代码。因此,如果 PART_ID 为 5,CAR_ID 为 3,并且我从列表中选择相同的数字,则会出现错误,我不知道为什么。

DECLARE
        --Varchar(100) or Number
      l_car Varchar(100);
      l_part Varchar(100);
    BEGIN
      SELECT CAR_ID, PART_ID INTO l_car, l_part FROM CAR_PARTS WHERE CAR_ID = :P99_CAR AND PARTS_ID = :P99_PARTS;
          IF l_car IS NULL OR l_parts IS NULL THEN 
              INSERT INTO CAR_PARTS (CAR_ID, PARTS_ID, CUR_AMOUNT) VALUES (:P99_CAR, :P99_PARTS, :P99_AMOUNT);
      ELSE
          UPDATE CAR_PARTS 
              SET CAR_ID = :P99_CAR,
                  PARTS_ID = :P99_PARTS,
                  CUR_AMOUNT = CUR_AMOUNT + :P99_AMOUNT
                      WHERE CAR_ID = :P99_CAR AND PARTS_ID = :P99_PARTS;
         END IF;
     END;

但是我在处理和提交时遇到 ORA-01403 错误

Ajax 调用返回服务器错误 ORA-01403:找不到执行 PL/SQL 代码的数据。

我知道我需要插入一个带有该错误的异常,但为什么它甚至会出现?

标签: sqlplsqloracle-apex

解决方案


您的SELECT语句没有返回任何行。由于这适用于不同的环境,因此您的绑定变量不是您认为的那样。您应该apex_debug.message在此过程中添加调用,然后检查调试日志中的值。

但是,我会用一个合并语句替换您的整个过程:

MERGE INTO car_parts cp
USING ( SELECT :P99_CAR_ID AS car_id, :P99_PARTS ID AS parts_id, 
               :P99_CUR_AMOUNT AS cur_amount ) src
   ON ( cp.car_id = src.car_id AND cp.parts_id = src.parts_id )
 WHEN NOT MATCHED THEN INSERT ( car_id, parts_id, cur_amount )
      VALUES ( src.car_id, src.parts_id, src.cur_amount )
 WHEN MATCED THEN UPDATE SET cur_amount = src.cur_amount

推荐阅读