SET SERVEROUTPUT ON
DECLARE
v_student_id NUMBER := &sv_student_id;
v_section_id NUMBER := 89;
v_final_grade NUMBER;
v_letter_grade CHAR(1);
BEGIN
SELECT final_grade
INTO v_final_grade
FROM enrollment
WHERE student_id = v_student_id
AND section_id = v_section_id;
CASE -- outer CASE
WHEN v_final_grade IS NULL THEN
DBMS_OUTPUT.PUT_LINE ('There is no final grade.');
ELSE
CASE -- inner CASE
WHEN v_final_grade >= 90 THEN v_letter_grade := 'A';
WHEN v_final_grade >= 80 THEN v_letter_grade := 'B';
WHEN v_final_grade >= 70 THEN v_letter_grade := 'C';
WHEN v_final_grade >= 60 THEN v_letter_grade := 'D';
ELSE v_letter_grade := 'F';
END CASE;
-- control resumes here after inner CASE terminates
DBMS_OUTPUT.PUT_LINE ('Letter grade is: '||v_letter_grade);
END CASE;
-- control resumes here after outer CASE terminates
END;
le code ci-dessus j'ai pris de l'oracle livre pl-sql par exemple quatrième édition 2009 mon problème est quand j'entrer dans un numéro d'étudiant ne figure pas dans la table, il me retourne les erreurs suivantesproblème PL/bloc SQL: Aucune donnée trouvée
Error report: ORA-01403: no data found ORA-06512: at line 7 01403. 00000 - "no data found" *Cause: *Action:
mais selon le livre aurait dû retourner une valeur nulle puis suivre le flux de cas ..
s'il vous plaît, aidez-moi ...
merci à l'avance
Y a-t-il une chance de formater votre PL SQL en code? – pjp
On dirait bien et joli maintenant :) – pjp