Nested Blocks and Variable Scope
1. What is wrong with this code? DECLARE v_a NUMBER; BEGIN v_a := 27; <<inner_block>> BEGIN v_a := 15; END;
Mark for Review (1) Points
The outer block has no label. Variable v_a is out of scope within the inner block and therefore cannot be referenced. The inner block has no END; statement. (*) Nothing is wrong, the code will execute successfully. Correct 2. A variable declared in an outer block is available in both the outer blocks and in any inner blocks. True or False? True False (*) Incorrect. Refer to Section 2 Lesson 6. 3. Examine the following code. Line A causes an exception. What will be displayed when the block is executed? DECLARE x NUMBER := 10; y NUMBER; BEGIN x := 15; y := 'Happy'; -- Line A x := 20; EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(x); END; 10 20 15 (*) Nothing is displayed Incorrect. Refer to Section 2 Lesson 6. 4. Examine the following code. What is the scope of variable v_myvar? Mark for Review Mark for Review (1) Points Mark for Review (1) Points
(1) Points DECLARE v_myvar NUMBER; BEGIN v_myvar := 6; DECLARE v_hervar NUMBER; BEGIN v_hervar := 4; END; END; Only the outer block Both the inner and the outer block (*) Only the inner block Neither block Incorrect. Refer to Section 2 Lesson 6. 5. What happens when an exception occurs in the executable section of a PL/SQL block? Oracle keeps trying to re-execute the statement which caused the exception. The remaining statements in the executable section are not executed. Instead, Oracle looks for an EXCEPTION section in the block. (*) The remaining statements in the executable section of the block are executed. The exception is always propagated to the calling environment. Incorrect. Refer to Section 2 Lesson 6. 6. An inner block is nested within an outer block. An exception occurs within the inner block, but the inner block does not have an EXCEPTION section. What happens? The exception is propagated to the outer block and the remaining executable statements in the outer block are skipped. (*) The exception is propagated to the outer block and the remaining executable statements in the outer block are executed. Oracle automatically tries to re-execute the inner block. The outer block is bypassed and the exception is always propagated to the calling environment. Correct 7. What values will be displayed when the following code is executed? DECLARE v_mynum NUMBER; BEGIN v_mynum := 7; DECLARE v_mynum NUMBER; Mark for Review (1) Points Mark for Review (1) Points Mark for Review (1) Points
BEGIN DBMS_OUTPUT.PUT_LINE(v_mynum); v_mynum := 3; END; DBMS_OUTPUT.PUT_LINE(v_mynum); END; 3,3 3,7 Null, 7 (*) Null, 3 Correct 8. For the anonymous block below, what is the correct reference to the father's date of birth in the inner block? <<outer>> DECLARE v_father_name VARCHAR2(20):='Patrick'; v_date_of_birth DATE:='20-Apr-1972'; BEGIN DECLARE v_child_name VARCHAR2(20):='Mike'; v_date_of_birth DATE:='12-Dec-2002'; ... v_date_of_birth.outer <<outer>>v_date_of_birth <<outer.v_date_of_birth>> outer.v_date_of_birth (*) Incorrect. Refer to Section 2 Lesson 6. 9. Examine the following code. At Line A, we want to assign a value of 25 to the outer block's variable (V1). What must we do? DECLARE v_myvar NUMBER; -- This is V1 BEGIN DECLARE v_myvar NUMBER := 8; BEGIN -- Line A END; END; At Line A, code: v_myvar := 25; Label both blocks and at line A, code: v_myvar := 25; It cannot be done because the outer block's v_myvar is out of scope at Line A. Label the outer block and (at Line A) dot-prefix v_myvar with the block label. Mark for Review (1) Points Mark for Review (1) Points
(*) It cannot be done because the outer block's v_myvar is in scope but not visible at Line A. Incorrect. Refer to Section 2 Lesson 6. 10. Examine the following nested blocks. Line B causes an exception. What will be displayed when this code is executed? DECLARE var_1 NUMBER; BEGIN var_1 := 4; DECLARE var_2 NUMBER; BEGIN var_2 := 'Unhappy'; -- Line B var_1 := 8; END; var_1 := 12; EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(var_1); END; Unhappy 12 8 4 (*) Incorrect. Refer to Section 2 Lesson 6 Mark for Review (1) Points
Good Programming Practices 1. Which of the Mark for Review following are (1) Points examples of good programming practice? (Choose two.) (Choose all correct answers) Use the %TYPE attribute to declare a variable according to another previously declared variable or database column. (*) Declare one or more identifiers per line for improved performance. For clarity, use column names as identifiers. Use meaningful names for identifiers. (*) Incorrect. Refer to Section 2 Lesson 7.
2. What symbol is used to comment a series of lines?
Mark for Review (1) Points
/ / before and after the comment /* */ before and after the comment (*) * * before and after the comment Incorrect. Refer to Section 2 Lesson 7. 3. Comments change how a PL/SQL program executes, so an unsuitable comment can cause the program to fail. True or False? True False (*) Incorrect. Refer to Section 2 Lesson 7. 4. Which of the following makes PL/SQL code easier to read and maintain? Mark for Review (1) Points Mark for Review (1) Points
Place multiple statements on the same line. Type everything in lowercase. Use suitable comments in the code. (*) Incorrect. Refer to Section 2 Lesson 7. 5. Which of the following are examples of good programming practice? (Choose three.) (Choose all correct answers) Document code with comments. (*) Use implicit data type conversions. Develop naming conventions for identifiers and other objects. (*) Indent code so that it can be read more easily. (*) Use table column names as the names of variables. Incorrect. Refer to Section 2 Lesson 7. 6. Examine the following code: DECLARE v_first_name varchar2 (30); v_salary number (10); BEGIN SELECT first_name, salary INTO v_first_name, v_salary FROM employees WHERE last_name = 'King'; END; Mark for Review (1) Points Mark for Review (1) Points
Which programming guideline would improve this code? Use a suitable naming convention for variables. Indent the code to make it more readable. (*) Use upper and lower case consistently. Incorrect. Refer to Section 2 Lesson 7.