Можете да го направите, като активирате проверката за грешки и след това повдигнете грешка.
ACCEPT p_cname PROMPT 'Enter Customer Name: '
WHENEVER SQLERROR EXIT SUCCESS ROLLBACK;
DECLARE
v_count INTEGER;
BEGIN
SELECT COUNT(*) INTO v_count
FROM customer
WHERE cname = '&p_cname';
IF v_count > 0 THEN
raise_application_error( -20100, 'Customer already exists' );
END IF;
END;
/
-- Issue a new WHENEVER statement here if you want different error-handling for
-- the rest of the script
-- Other ACCEPT statements if a match was not found.
В WHENEVER
команда, SUCCESS
ключова дума означава, че SQLPlus ще върне успешен код обратно на обвивката, от която е бил извикан. Можете също да използвате FAILURE
за връщане на общ код за грешка или други опции за връщане на конкретни стойности.