PLSQL

Download as txt, pdf, or txt
Download as txt, pdf, or txt
You are on page 1of 49

1. Examine the following nested blocks. Line B causes an exception.

What wi
ll 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; Mark for Review
(1) Points

Unhappy

12

4 (*)

Incorrect. Refer to Section 2 Le


sson 6.

2. Examine the following code. What is the scope of variabl


e v_myvar?
DECLARE
v_myvar NUMBER;
BEGIN
v_myvar := 6;
DECLARE
v_hervar NUMBER;
BEGIN
v_hervar := 4;
END;
END; Mark for Review
(1) Points

Only the outer block

Both the inner and the outer block (*)

Only the inner block


Neither block

Incorrect. Refer to Section 2 Le


sson 6.

3. 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 refe
renced.

The inner block has no END; statement. (*)

Nothing is wrong, the code will execute successfully.

Correct

4. For the anonymous block below, what is the correct refer


ence 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';
... Mark for Review
(1) Points

v_date_of_birth.outer

<<outer>>v_date_of_birth

<<outer.v_date_of_birth>>

outer.v_date_of_birth (*)
Correct

5. What happens when an exception occurs in the executable


section of a PL/SQL block? Mark for Review
(1) Points

Oracle keeps trying to re-execute the statement which caused the exception.

The remaining statements in the executable section are not executed. Instead, Or
acle 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.

Correct

6. A variable is global to an outer block and local to the


inner block. True or False? Mark for Review
(1) Points

True

False (*)

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;
BEGIN
DBMS_OUTPUT.PUT_LINE(v_mynum);
v_mynum := 3;
END;
DBMS_OUTPUT.PUT_LINE(v_mynum);
END; Mark for Review
(1) Points

3,3

3,7
Null, 7 (*)

Null, 3

Correct

8. An inner block is nested within an outer block. An excep


tion occurs within the inner block, but the inner block does not have an EXCEPTI
ON section. What happens? Mark for Review
(1) Points

The exception is propagated to the outer block and the remaining executable stat
ements in the outer block are skipped. (*)

The exception is propagated to the outer block and the remaining executable stat
ements 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 callin
g environment.

Incorrect. Refer to Section 2 Le


sson 6.

9. 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; Mark for Review
(1) Points

10

20

15 (*)
Nothing is displayed

Correct

10. 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; Mark for Review
(1) Points

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.
(*)

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 Le


sson 6.

1. To modify an existing row in a table, you can use the ________ statemen
t. Mark for Review
(1) Points

MODIFY

INSERT

ALTER

UPDATE (*)
Incorrect. Refer to Section 3 Lesson 1.

2. Look at this SQL statement:


MERGE INTO old_trans ot
USING new_trans nt
ON (ot.trans_id = nt.trans_id) .... ;
OLD_TRANS is the source table and NEW_TRANS is the target table. True or false?
Mark for Review
(1) Points

True

False (*)

Correct

3. What would be the result of the following statement: DE


LETE employees; Mark for Review
(1) Points

Nothing, no data will be changed.

All rows in the employees table will be deleted. (*)

The statement will fail because it contains a syntax error.

The row with EMPOYEE_ID=100 will be deleted.

Correct

4. When inserting a row into a table, the VALUES clause mu


st include a value for every column of the table. True or False? Mark for
Review
(1) Points

True

False (*)
Correct

5. What is wrong with the following statement?


DELETE from employees WHERE salary > (SELECT MAX(salary) FROM employees);
Mark for Review
(1) Points

You cannot code a subquery inside a DELETE statement.

You cannot use inequality operators such as "<" and ">" inside a DELETE
statement.

Nothing is wrong, the statement will execute correctly. (*)

Correct

6. What is wrong with the following statement?


MERGE INTO emps e
USING new_emps ne
ON (e.employee_id = ne.employee_id)
WHEN MATCHED
THEN UPDATE SET ne.salary = e.salary
WHEN NOT MATCHED
THEN INSERT VALUES
(ne.employee_id, ne.first_name, ne.last_name, .... ne.salary, ....);
Mark for Review
(1) Points

The UPDATE clause must include the target table name: UPDATE emps SET ..
..

The INSERT clause must include a column list as well as a list of column
values.

The SET clause is trying to update the source table from the target tabl
e. (*)

Nothing is wrong, the statement will execute correctly.

Incorrect. Refer to Section 3 Lesson 1.

7. You want to modify existing rows in a table. Which of t


he following are NOT needed in your SQL statement? (Choose two). Mark for
Review
(1) Points
A MODIFY clause.

An UPDATE clause.

The name of the table.

The name of the column(s) you want to modify.

A new value for the column you want to modify (this can be an expression
or a subquery).

A WHERE clause, (*)

Incorrect. Refer to Section 3 Lesson 1.

8. Is it possible to insert more than one row at a time us


ing an INSERT statement with a VALUES clause? Mark for Review
(1) Points

No, you can only create one row at a time when using the VALUES clause.
(*)

Yes, you can list as many rows as you want, just remember to separate th
e rows with commas.

No, there is no such thing as INSERT ... VALUES.

Correct
1. When used in a PL/SQL block, which SQL statement must return exactly on
e row? Mark for Review
(1) Points

INSERT

UPDATE

SELECT (*)

MERGE
DELETE

Correct

2. It is good programming practice to create identifiers h


aving the same name as column names. True or False? Mark for Review
(1) Points

True

False (*)

Correct

3. Which of the following is NOT a valid guideline for ret


rieving data in PL/SQL? Mark for Review
(1) Points

Terminate the SQL statement with a semicolon (;)

Do NOT use a WHERE clause in SELECT statements. (*)

Where possible, declare variables using the %TYPE attribute.

Specify the same number of variables in the INTO clause as database colu
mns in the SELECT clause.

Correct

4. Does PL/SQL allow you to have a variable with the same


name as a database column? Mark for Review
(1) Points

No

Yes (*)

Correct

5. Which SQL statements can be used directly in a PL/SQL b


lock? (Choose two.) Mark for Review
(1) Points
(Choose all correct answers)

GRANT EXECUTE ON ...

SELECT * INTO ... (*)

REVOKE SELECT ON ...

UPDATE employees SET... (*)

ALTER TABLE employees ...

Incorrect. Refer to Section 3 Lesson 2.

6. What will happen when the following block is executed?


DECLARE
v_last employees.last_name%TYPE;
v_first employees.first_name%TYPE;
v_salary employees.salary%TYPE;
BEGIN
SELECT first_name, last_name
INTO v_first, v_last, v_salary
FROM employees WHERE employee_id=100;
END;
Mark for Review
(1) Points

The block will fail because the SELECT statement returns more than one r
ow.

The block will fail because the SELECT is trying to read two columns int
o three PL/SQL variables. (*)

The block will fail because V_LAST was declared before V_FIRST.

The block will execute successfully, and the V_SALARY variable will be s
et to NULL.

Correct

7. Which one of these SQL statements can be directly inclu


ded in a PL/SQL executable block? Mark for Review
(1) Points

IF... THEN...;

INSERT INTO...; (*)

SELECT * FROM DUAL;

SHOW USER;

Incorrect. Refer to Section 3 Lesson 2.

8. Look at this PL/SQL block:


DECLARE
v_count NUMBER;
BEGIN
SELECT COUNT(*) INTO v_count
FROM employees WHERE salary > 50000;
END;
No employees earn more than $50,000. Which of the following statements are true?
(Choose two).
Mark for Review
(1) Points
(Choose all correct answers)

The SELECT will return value 0 into V_COUNT. (*)

The SELECT will fail because it does NOT return exactly one row.

The block will fail because variable V_SALARY was not declared.

The SELECT returns exactly one row. (*)

The block will fail because no results are displayed to the user.
1. There are three employees in department 90. What will be displayed when
the following code is executed?
DECLARE
v_open CHAR(3) := 'NO';
BEGIN
UPDATE employees SET job_id = 'ST_CLERK'
WHERE department_id = 90;
IF SQL%FOUND THEN
v_open := 'YES';
END IF;
DBMS_OUTPUT.PUT_LINE(v_open || ' ' || SQL%ROWCOUNT);
END;
Mark for Review
(1) Points

NO 3

YES 1

YES 3 (*)

Nothing will be displayed. The block will fail because you cannot use im
plicit cursor attributes directly in a call to DBMS_OUTPUT.PUT_LINE.

Correct

2. Which implicit cursor attribute identifies the number of


rows updated in the following statement?
...
DBMS_OUTPUT.PUT_LINE(__________ || ' rows updated.');
...
Mark for Review
(1) Points

SQL%COUNT

SQL%NUMBER

SQL%ROWCOUNT (*)

SQLROW%COUNT

Correct

3. A PL/SQL block contains the following DML statement:


UPDATE wf_countries SET population = population * 1.1
WHERE country_id = 229;
Which kind of cursor is used for this statement?
Mark for Review
(1) Points

An implicit cursor named "WF_COUNTRIES".


An implicit cursor named "SQL". (*)

An explicit cursor named "SQL".

An explicit cursor which must be declared and named by the PL/SQL progra
mmer.

Correct

4. Employee_id 999 does not exist. What will happen when th


e following code is executed?
DECLARE
employee_id employees.employee_id%TYPE := 999;
BEGIN
UPDATE employees SET salary = salary * 1.1
WHERE employee_id = employee_id;
END;
Mark for Review
(1) Points

No rows are updated but the block completes successfully.

Every employee row is updated. (*)

An exception is raised because you cannot give a variable the same name
as a table column.

An exception is raised because the UPDATE statement did not modify any r
ows.

Incorrect Refer to Section 3 Lesson 3.

5. Which of the following use an implicit cursor? Mark for


Review
(1) Points

DML statements only.

SELECT statements only.

DML statements and SELECT statements which return a single row. (*)
COMMIT and ROLLBACK statements only.
1. How many transactions are in the following block?
BEGIN
INSERT INTO countries (country_id, country_name)
VALUES ('XA', 'Xanadu');
INSERT INTO countries (country_id, country_name)
VALUES ('NV', 'Neverland');
UPDATE countries SET country_name='Deutchland'
WHERE country_id='DE';
UPDATE countries SET region_id=1
WHERE country_name LIKE '%stan';
END;
How many transactions are shown above?
Mark for Review
(1) Points

Four; each DML is a separate transaction

Two; both the INSERTs are one transaction and both the UPDATEs are a sec
ond transaction.

It depends on how many rows are updated - there will be a separate trans
action for each row.

One (*)

Incorrect. Refer to Section 3 Lesson 4.

2. How many INSERTs can you have in one transaction?


Mark for Review
(1) Points

One

As many as you want until you do a COMMIT or ROLLBACK. (*)

As many as you can execute before the database does an AUTOSAVE.

As many as you want until a different DML statement (UPDATE, DELETE or M


ERGE) is executed.

Incorrect. Refer to Section 3 Lesson 4.


3. In a PL/SQL block, where can you code a COMMIT statemen
t? Mark for Review
(1) Points

In any section of the block: Declaration, Executable, or Exception.

Only the Executable section.

In the Executable and/or the Exception sections. (*)

Nowhere; the COMMIT statement must be outside the block.

Correct

4. Examine the following code: BEGIN


INSERT INTO animals VALUES ('aa','aardvarks');
SAVEPOINT sp_1;
INSERT INTO animals VALUES ('bb','big birds');
SAVEPOINT sp_2;
ROLLBACK TO sp_1;
INSERT INTO animals VALUES ('cc','cool cats');
COMMIT;
END;
Which row(s) will be in the ANIMALS table after this block is executed? Mark for
Review
(1) Points

cool cats

big birds and cool cats

aardvaarks and cool cats (*)

aardvaarks, big birds and cool cats

Correct
1. We want to execute one of three statements depending on whether the valu
e in V_VAR is 10, 20 or some other value. What should be coded at Line A?
IF v_var = 10 THEN
statement1;
-- Line A
statement2;
ELSE
statement3;
END IF;
Mark for Review
(1) Points

ELSE IF v_var = 20 THEN

ELSIF v_var = 20

ELSIF v_var = 20 THEN (*)

IF v_var = 20 THEN

Incorrect. Refer to Section 4 Lesson 1.

2. You want to repeat a set of statements 100 times, incre


menting a counter each time. What kind of PL/SQL control structure would you use
? Mark for Review
(1) Points

IF...THEN...ELSE

IF...THEN...ELSIF...ELSE

CASE...WHEN...THEN

A loop. (*)

Correct

3. What is wrong with the following trivial IF statement:


IF (v_job='President')
THEN v_salary := 10000;
Mark for Review
(1) Points

IF and THEN must be on the same line: IF (v_job='President') THEN ...

The condition should be coded: IF (v_job := 'President')

END IF; is missing (*)

ELSE is missing
Incorrect. Refer to Section 4 Lesson 1.

4. Look at the following (badly written) code:


age := 5;
IF age<30 THEN mature := 'adult';
ELSIF age<22 THEN mature := 'teenager';
ELSIF age<13 THEN mature := 'child';
END IF;
DBMS_OUTPUT.PUT_LINE(mature);
What will be displayed when this code is executed?
Mark for Review
(1) Points

child

teenager

adult (*)

adultteenagerchild

Incorrect. Refer to Section 4 Lesson 1.

5. Name three types of control structures in PL/SQL. (Choo


se three) Mark for Review
(1) Points
(Choose all correct answers)

LOOP statements (*)

SELECT statements

EXCEPTIONS

IF statements (*)

CASE statements (*)

Correct
6. What will be displayed when this block is executed?
DECLARE
v_birthdate DATE;
BEGIN
IF v_birthdate < '01-JAN-2000'
THEN
DBMS_OUTPUT.PUT_LINE(' Born in the 20th century ');
ELSE
DBMS_OUTPUT.PUT_LINE(' Born in the 21st century ');
END IF;
END;
Mark for Review
(1) Points

Born in the 20th century

Born in the 21st century (*)

Exception raised because no date given

Correct

7. Which one of the following is correct syntax for an IF


statement? Mark for Review
(1) Points

IF condition THEN DO statement1; statement2; END IF;

IF condition THEN statement1; statement2; END IF; (*)

IF condition THEN statement1; statement2; ENDIF;

IF condition THEN statement1; AND statement2; END IF;

Correct

8. What will be displayed when this block is executed?


DECLARE
v_bool1 BOOLEAN := TRUE;
v_bool2 BOOLEAN;
v_char VARCHAR(4) := 'up';
BEGIN
IF (v_bool1 AND v_bool2) THEN
v_char:='down';
ELSE v_char:='left';
END IF;
DBMS_OUTPUT.PUT_LINE(v_char);
END;
Mark for Review
(1) Points

up

down

left (*)

null

Correct

9. What will be displayed when this block is executed?


DECLARE
v_bool1 BOOLEAN := NULL;
v_bool2 BOOLEAN := NULL;
v_char VARCHAR(10) := 'Start';
BEGIN
IF (v_bool1 = v_bool2) THEN
v_char:='Equal';
ELSE v_char:='Not equal';
END IF;
DBMS_OUTPUT.PUT_LINE(v_char);
END;
Mark for Review
(1) Points

Equal

Not equal (*)

Start

Nothing will be displayed. The block will fail because you cannot compar
e two null values.

Correct

10. Which of the following statements are true about any of


the PL/SQL conditional control structures such as IF ... , CASE ... and loops?
Mark for Review
(1) Points
They allow the programmer to use logical tests to determine which statem
ents are executed and which are not.

They allow a set of statements to be executed repeatedly (i.e. more than


once).

They determine a course of action based on conditions.

All of the above. (*)

Correct

11. A basic loop is a type of control structure used to cha


nge the logical flow of statements in a PL/SQL block. True or False? Mark for
Review
(1) Points

True (*)

False

Incorrect. Refer to Section 4 Lesson 1.


Incorrect Refer to Section 3 Lesson 3.

6. Which of the following SQL DML commands can be used ins


ide a PL/SQL block? Mark for Review
(1) Points

INSERT and UPDATE only.

UPDATE and DELETE only.

INSERT, UPDATE and DELETE only.

INSERT, UPDATE, DELETE and MERGE. (*)

Correct

7. You can use implicit cursor attributes such as SQL%ROWC


OUNT directly inside a DML statement. For example: INSERT INTO log_table VALUES
(SYSDATE, USER, SQL%ROWCOUNT); True or False? Mark for Review
(1) Points

True

False (*)

Incorrect Refer to Section 3 Lesson 3.


1. Look at the following code:
DECLARE
x BOOLEAN := FALSE;
y BOOLEAN := FALSE;
z BOOLEAN ;
BEGIN
z := (x OR NOT y);
-- Line A
....
END;
What is the value of Z at Line A?
Mark for Review
(1) Points

True (*)

False

NULL

An error will occur because you cannot combine two Boolean variables usi
ng "NOT".

Correct

2. How must you end a CASE statement? Mark for Review


(1) Points

END;

END CASE; (*)

END IF;

ENDCASE;
Correct

3. Examine the following code:


DECLARE
v_score NUMBER(3);
v_grade CHAR(1);
BEGIN
CASE v_score
-- Line A
....
The CASE statement must convert a numeric score to a letter grade: 90 -> A, 80 -
> B, 70 -> C and so on.
What should be coded at Line A?
Mark for Review
(1) Points

WHEN 90 THEN v_grade := 'A'

WHEN 90 THEN v_grade := 'A'; (*)

WHEN 90 THEN 'A'

WHEN 90 THEN 'A';

Correct

4. How must you end a CASE expression? Mark for Review


(1) Points

END; (*)

ENDIF;

END CASE;

ENDCASE;

Correct

5. What will be displayed when the following block is execu


ted?
DECLARE
v_age1 NUMBER(3);
v_age2 NUMBER(3);
v_message VARCHAR2(20);
BEGIN
CASE
WHEN v_age1 = v_age2 THEN v_message := 'Equal';
WHEN v_age1 <> v_age2 THEN v_message := 'Unequal';
ELSE v_message := 'Undefined';
END CASE;
DBMS_OUTPUT.PUT_LINE(v_message);
END;
Mark for Review
(1) Points

Equal

Undefined (*)

Unequal

Nothing will be displayed because V_MESSAGE is set to NULL.

Incorrect. Refer to Section 4 Lesson 2.

6. Examine the following code:


DECLARE
v_score NUMBER(3);
v_grade CHAR(1);
BEGIN
v_grade := CASE v_score
-- Line A
....
The CASE expression must convert a numeric score to a letter grade: 90 -> A, 80
-> B, 70 -> C and so on. What should be coded at Line A?
Mark for Review
(1) Points

WHEN 90 THEN grade := 'A'

WHEN 90 THEN v_grade := 'A';

WHEN 90 THEN 'A' (*)

WHEN 90 THEN 'A';


Incorrect. Refer to Section 4 Lesson 2.

7. Examine the following code:


DECLARE
v_a BOOLEAN;
v_b BOOLEAN := FALSE;
v_c BOOLEAN ;
BEGIN
v_c := (v_a AND v_b);
-- Line A
....
END;
What is the value of V_C at Line A?
Mark for Review
(1) Points

True

False (*)

NULL

Undefined

Incorrect. Refer to Section 4 Lesson 2.

8. What will be displayed when the following block is execu


ted?
DECLARE
v_age NUMBER(3);
v_gender VARCHAR2(6) := 'Female';
v_status VARCHAR2(20);
BEGIN
CASE
WHEN v_age >= 18 AND v_gender = 'Male' THEN v_status := 'Adult Male';
WHEN v_age >= 18 AND v_gender = 'Female' THEN v_status := 'Adult Female';
WHEN v_age < 18 AND v_gender = 'Male' THEN v_status := 'Junior Male';
WHEN v_age < 18 AND v_gender = 'Female' THEN v_status := 'Junior Female';
ELSE v_status := 'Other Value';
END CASE;
DBMS_OUTPUT.PUT_LINE(v_status);
END;
Mark for Review
(1) Points

Adult Male

Junior Female
Other Value (*)

Nothing will be displayed because V_STATUS is set to NULL.

Correct
1. For which one of these tasks should you use a PL/SQL loop? Mark for
Review
(1) Points

Updating the salary of one employee.

Executing the same set of statements repeatedly until a condition become


s true. (*)

Deciding whether a value is within a range of numbers.

Making a decision based on whether a condition is true or not.

Correct

2. Which kind of loop is this?


i := 10;
LOOP
i := i + 1;
EXIT WHEN i > 30;
END LOOP;
Mark for Review
(1) Points

A FOR loop.

A WHILE loop.

A basic loop. (*)

An infinite loop.

A nested loop.

Correct
3. Examine the following code::
DECLARE
v_count NUMBER := 0;
v_string VARCHAR2(20);
BEGIN
LOOP
v_string := v_string || 'x';
IF LENGTH(v_string) > 10 THEN
EXIT;
END IF;
v_count := v_count + 1;
END LOOP;
DBMS_OUTPUT.PUT_LINE(v_count);
END;
What will be displayed when this block is executed?
Mark for Review
(1) Points

10 (*)

11

xxxxxxxxxxx

Incorrect. Refer to Section 4 Lesson 3.

4. What will be displayed when this block is executed?


DECLARE
v_count NUMBER := 10;
v_result NUMBER;
BEGIN
LOOP
v_count := v_count - 1;
EXIT WHEN v_count < 5;
v_result := v_count * 2;
END LOOP;
DBMS_OUTPUT.PUT_LINE(v_result);
END;
Mark for Review
(1) Points

10 (*)

12
NULL

Correct

5. Look at this code:


DECLARE
v_bool BOOLEAN := TRUE;
v_date DATE;
BEGIN
LOOP
EXIT WHEN v_bool;
SELECT SYSDATE INTO v_date FROM dual;
END LOOP;
END;
How many times will the SELECT statement execute?
Mark for Review
(1) Points

Once.

Twice.

Never (the SELECT will not execute at all) (*)

An infinite number of times because the EXIT condition will never be tru
e

Correct

6. You want to calculate and display the multiplication ta


ble for "sevens": 7x1=7, 7x2=14, 7x3=21 and so on. Which kind of PL/SQL construc
t is best for this? Mark for Review
(1) Points

A loop (*)

A CASE statement

IF ... END IF;

A Boolean variable.
Correct

7. What are the three kinds of loops in PL/SQL? Mark for


Review
(1) Points

ascending, descending, unordered

infinite, finite, recursive

IF, CASE, LOOP

FOR, WHILE, basic (*)

Correct

8. How many EXIT statements can be coded inside a basic lo


op? Mark for Review
(1) Points

None.

One only.

Two.

As many as you need, there is no limit. (*)

Incorrect. Refer to Section 4 Lesson 3.


1. In a FOR loop, an explicitly declared counter is automatically incremen
ted by 1 for each iteration of the loop. True or False? Mark for Review
(1) Points

True

False (*)

Incorrect. Refer to Section 4 Lesson 4.

2. Look at this code fragment: FOR i IN 1 .. 3 LOOP i := 4


; DBMS_OUTPUT.PUT_LINE('The counter is: ' || i); END LOOP; How many lines of out
put will be displayed? Mark for Review
(1) Points

One

Three

Four

The block will fail because you cannot change the value of i inside the
loop. (*)

Correct

3. Look at the following block:


DECLARE
v_date DATE := SYSDATE;
BEGIN
WHILE v_date < LAST_DAY(v_date) LOOP
v_date := v_date + 1;
END LOOP;
DBMS_OUTPUT.PUT_LINE(v_date);
END;
If today's date is 17th April 2007, what will be displayed when this block execu
tes?
Mark for Review
(1) Points

01-MAY-07

31-DEC-07

4/30/2007 (*)

4/17/2007

Correct

4. In a WHILE loop, the controlling condition is checked a


t the start of each iteration. True or False? Mark for Review
(1) Points

True (*)
False

Correct

5. You should use a WHILE loop when the number of iteratio


ns of the loop is known in advance. True or False? Mark for Review
(1) Points

True

False (*)

Correct

6. Which statement best describes when a FOR loop should b


e used? Mark for Review
(1) Points

When an EXIT WHEN statement must be coded.

When an implicitly declared counter must increase by 1 in each iteration


of the loop. (*)

When we want to exit from the loop when a Boolean variable becomes FALSE
.

When the statements inside the loop must execute at least once.

Correct

7. You want a loop that counts backwards from 10 through 1


. How do you code that? Mark for Review
(1) Points

FOR i IN 10 .. 1 LOOP

FOR i IN 1 .. 10 BY -1 LOOP

FOR i IN REVERSE 1 .. 10 LOOP (*)


FOR i IN REVERSE 10 .. 1 LOOP

Correct

8. Look at the following code fragment:


i := 2;
WHILE i < 3 LOOP
i := 4;
DBMS_OUTPUT.PUT_LINE('The counter is: ' || i);
END LOOP;
How many lines of output will be displayed?
Mark for Review
(1) Points

No lines

One line (*)

Two lines

The block will fail because you cannot use DBMS_OUTPUT.PUT_LINE inside a
loop.

Correct
1. Which one of these statements about using nested loops is true?
Mark for Review
(1) Points

All the loops must be labelled

The outer loop must be labelled, but the inner loop need not be labelled

The outer loop must be labelled if you want to exit the outer loop from
within the inner loop (*)

Both loops can have the same label

Correct

2. What statement allows you to exit the outer loop at Poin


t A in the following block?
DECLARE
v_outer_done CHAR(3) := 'NO';
v_inner_done CHAR(3) := 'NO';
BEGIN
LOOP -- outer loop
...
LOOP -- inner loop
...
... -- Point A
EXIT WHEN v_inner_done = 'YES';
...
END LOOP;
...
EXIT WHEN v_outer_done = 'YES';
...
END LOOP;
END;
Mark for Review
(1) Points

EXIT AT v_outer_done = 'YES';

EXIT WHEN v_outer_done = 'YES'; (*)

WHEN v_outer_done = YES EXIT;

EXIT <<outer loop>>;

Correct

3. What type of loop statement would you write for Point A?


BEGIN
FOR v_outerloop IN 1..3 LOOP
-- Point A
DBMS_OUTPUT.PUT_LINE('Outer loop is:'||v_outerloop||
' and inner loop is: '||v_innerloop);
END LOOP;
END LOOP;
END;
Mark for Review
(1) Points

WHILE v_innerloop <=5 LOOP

FOR v_innerloop 1..5 LOOP (*)

LOOP

WHILE v_outerloop<v_innerloop LOOP


Incorrect. Refer to Section 4 Lesson 5.

4. What will be displayed when the following block is execu


ted?
DECLARE
x NUMBER(6) := 0 ;
BEGIN
FOR i IN 1..10 LOOP
FOR j IN 1..5 LOOP
x := x+1 ;
END LOOP;
END LOOP;
DBMS_OUTPUT.PUT_LINE(x);
END;
Mark for Review
(1) Points

10

15

50 (*)

Correct

5. When the following code is executed, how many lines of o


utput will be displayed?
BEGIN
FOR i IN 1..5 LOOP
FOR j IN 1..8 LOOP
DBMS_OUTPUT.PUT_LINE(i || ',' || j);
END LOOP;
DBMS_OUTPUT.PUT_LINE(i);
END LOOP;
END;
Mark for Review
(1) Points

80

45 (*)

14
41

Correct

6. Look at the following code:


DECLARE
v_blue NUMBER(3) := 0;
v_red NUMBER(3) := 0;
BEGIN
<< blue >> LOOP
v_blue := v_blue + 1;
EXIT WHEN v_blue > 10;
<< red >> LOOP
v_red := v_red + 1;
EXIT WHEN v_red > 10;
-- Line A
END LOOP red;
END LOOP blue;
END;
What should you code at Line A to exit from the outer loop?
Mark for Review
(1) Points

EXIT;

EXIT red;

EXIT <<blue>>;

EXIT blue; (*)

Correct
1. How must you reference one field which is part of a PL/SQL record?
Mark for Review
(1) Points

field_name.record_name

record_name.field_name (*)

record_name(field_name)

field_name OF record_name
It cannot be done.

Correct

2. Examine the following code:


DECLARE
CURSOR country_curs IS
SELECT country_id, country_name
FROM wf_countries
ORDER BY country_name;
v_country country_curs%ROWTYPE;
BEGIN
OPEN country_curs;
LOOP
FETCH country_curs INTO v_country;
EXIT WHEN country_curs%NOTFOUND;
------- Line A
END LOOP;
CLOSE country_curs;
END;
You want to display the id and name of each FETCHed country. What would you code
at Line A?
Mark for Review
(1) Points

DBMS_OUTPUT.PUT_LINE(country_id || ' ' || country_name);

DBMS_OUTPUT.PUT_LINE(v_country(country_id) || ' ' || v_country(country_n


ame));

DBMS_OUTPUT.PUT_LINE(country_curs.country_id || ' ' || country_curs.coun


try_name);

DBMS_OUTPUT.PUT_LINE(v_country.country_id || ' ' || v_country.country_na


me); (*)

Correct

3. Look at these declarations:


DECLARE
CURSOR dept_loc_cursor IS
SELECT department_id, department_name, location_name
FROM departments d, locations l
WHERE d.location_id = l.location_id;
v_dept_loc dept_loc_cursor%ROWTYPE;
How many fields does V_DEPT_LOC contain?
Mark for Review
(1) Points

Two, because the cursor joins two tables

Four

Three (*)

None

Correct

4. Look at the following code:


DECLARE
CURSOR emp_cursor IS
SELECT employee_id, last_name, salary FROM employees;
v_empcurs emp_cursor%ROWTYPE;
What is the data type of V_EMPCURS?
Mark for Review
(1) Points

Scalar

Record (*)

Cursor

Row

Correct

5. You can reference explicit cursor attributes directly i


n a SQL statement. True or False? Mark for Review
(1) Points

True

False (*)
Correct

6. Which of the following explicit cursor attributes evalu


ates to TRUE if the most recent FETCH returns a row? Mark for Review
(1) Points

%ISOPEN

%NOTFOUND

%FOUND (*)

%ROWCOUNT

Correct

7. You have declared the following cursor:


CURSOR country_curs IS
SELECT * FROM wf_countries
ORDER BY country_name;
There are over 200 rows in the WF_COUNTRIES table, but you want to fetch and dis
play only the first 25 rows.
How would you exit from the FETCH loop?
Mark for Review
(1) Points

EXIT WHEN country_curs%FOUND(25);

EXIT WHEN country_curs%ROWCOUNT > 25; (*)

EXIT WHEN ROWCOUNT > 25;

WHEN country_curs > 25 THEN EXIT; END IF;

Correct
1. A cursor FOR loop using a subquery can extensiv
ely shorten code length when compared to an explicit cursor declaration. True or
False? Mark for Review
(1) Points
True (*)

False

Correct

2. Which one of the following is a valid cursor FOR loop w


ith a subquery? Mark for Review
(1) Points

FOR emp_rec IN (SELECT last_name || first_name FROM employees) LOOP ...

FOR emp_rec IN (SELECT UPPER(last_name) FROM employees) LOOP ...

FOR emp_rec IN SELECT last_name, salary*12 "ANNSAL" FROM employees LOOP


...

FOR emp_rec IN (SELECT last_name, salary*12 "ANNSAL" FROM employees) LOO


P ... (*)

None of the above.

Incorrect. Refer to Section 5 Lesson 3.

3. Which of the following is a benefit of using a cursor F


OR loop? Mark for Review
(1) Points

The exception handling is done automatically. .

The OPEN, CLOSE, FETCH and EXIT from the loop are done automatically. (*
)

You can OPEN the same cursor twice at the same time.

Because there is less code, the loop executes faster.

%ROWCOUNT increments automatically each time a row is FETCHed.

Incorrect. Refer to Section 5 Lesson 3.


4. Look at the following code:
DECLARE
CURSOR emp_cursor IS SELECT * FROM employees;
BEGIN
FOR emp_record IN emp_cursor LOOP
DBMS_OUTPUT.PUT_LINE( --Point A -- );
END LOOP;
END;
To display the salary of an employee, what code should you write at Point A?
Mark for Review
(1) Points

emp_record.salary (*)

emp_cursor.salary

employees.salary

emp_record.employees.salary

TO_CHAR(salary)

Correct

5. You have declared a cursor as follows:


CURSOR loc_curs IS SELECT * FROM locations;
How should you code a FOR loop to use this cursor?
Mark for Review
(1) Points

FOR loc_rec IN 1 .. loc_curs%ROWCOUNT LOOP ...

WHILE loc_rec IN loc_curs LOOP ...

FOR loc_curs IN loc_rec LOOP ...

IF loc_rec IN loc_curs LOOP ...

FOR loc_rec IN loc_curs LOOP ... (*)

Correct
6. What is the DISadvantage of using a cursor FOR loop wit
h a subquery? Mark for Review
(1) Points

You cannot reference cursor attributes such as %NOTFOUND. (*)

The execution speed is slower.

You cannot declare the cursor in the declaration section.

You cannot use the cursor to join two or more tables.

There are no disadvantages.

Correct

7. What is wrong with the following piece of code?


BEGIN
FOR emp_record IN emp_cursor LOOP
DBMS_OUTPUT.PUT_LINE(emp_record.last_name);
END LOOP;
IF emp_record.last_name = 'Patel' THEN ...
Mark for Review
(1) Points

EMP_RECORD has not been explicitly declared.

The cursor has not been OPENed.

You cannot reference EMP_RECORD outside the loop. (*)

It should read: DBMS_OUTPUT.PUT_LINE(emp_cursor.last_name);

Nothing is wrong, the code will execute correctly.

Correct
1. The following cursor has been declared:
CURSOR emp_curs
(p_dept_id employees.department_id%TYPE,
p_job_id employees.job_id%TYPE) IS
SELECT * FROM employees
WHERE department_id = p_dept_id
AND job_id = p_job_id;
Which of the following will correctly open the cursor?
Mark for Review
(1) Points

OPEN emp_curs(20);

FOR emp_rec IN emp_curs(20) LOOP ...

OPEN emp_curs('IT_PROG', 20);

FOR emp_rec IN emp_curs(20,'IT_PROG') LOOP ... (*)

FOR emp_rec IN emp_curs(p_dept_id p_job_id) LOOP ...

Correct

2. Using parameters with a cursor, you can open and close


the cursor several times in a block, returning a different active set each time.
True or False? Mark for Review
(1) Points

True (*)

False

Correct

3. Look at the following code:


DECLARE
CURSOR emp_curs (p_dept_id employees.department_id%TYPE) IS
SELECT * FROM employees
WHERE department_id = p_dept_id;
v_emp_rec emp_curs%ROWTYPE;
v_deptid NUMBER(4) := 50;
BEGIN
OPEN emp_curs( -- Point A --);
....
You want to open the cursor, passing value 50 to the parameter. Which of the fol
lowing are correct at Point A?
Mark for Review
(1) Points
50

v_deptid

100 / 2

All of the above. (*)

Incorrect. Refer to Section 5 Lesson 4.

4. You want to use explicit cursors to fetch and display a


ll the countries in a specific region. There are 19 rows in the WF_WORLD_REGIONS
table. You want to use a different region each time the cursor is opened. How m
any cursors should you declare? Mark for Review
(1) Points

19 cursors, all in the same PL/SQL block.

19 cursors in 19 PL/SQL blocks (one in each block).

20 cursors, in case an extra row is inserted into WF_WORLD_REGIONS later


.

One cursor with a parameter in the WHERE clause. (*)

None of the above.

Correct

5. What is wrong with the following cursor declaration?


SELECT * FROM departments
WHERE location_id = p_loc_id;
Mark for Review
(1) Points

You cannot reference a cursor parameter in a WHERE clause.

The parameter should be coded as: (p_loc_id NUMBER) (*)

The parameter should be coded as: (p_loc_id IN NUMBER)


Nothing is wrong, the cursor declaration is correct.

Correct

1. When can we use the WHERE CURRENT OF clause? Mark for


Review
(1) Points

Only with an UPDATE, not with a DELETE.

Only with a DELETE, not with an UPDATE.

When the cursor is declared as SELECT ... FOR UPDATE ...; (*)

When the cursor is based on a single table (not on a join).

When the cursor has not been OPENed.

Correct

2. You have declared a cursor as SELECT .... FOR UPDATE; Y


ou have OPENed the cursor and locked the FETCHed rows. When are these row locks
released? Mark for Review
(1) Points

When an UPDATE ... WHERE CURRENT OF cursor_name; is executed.

When you CLOSE the cursor.

When your block finishes executing.

When you explicitly COMMIT or ROLLBACK your transaction. (*)

When another user tries to SELECT the rows.

Incorrect. Refer to Section 5 Lesson 2.

3. You have declared the following cursor: CURSOR country_


curs IS SELECT country_id, country_name FROM wf_countries FOR UPDATE WAIT 10; An
other user updates a row in WF_COUNTRIES but does not COMMIT the update. What wi
ll happen when you OPEN country_curs; ? Mark for Review
(1) Points

A LOCKED_ROWS exception is raised immediately.

The other user's transaction is automatically rolled back.

Your session waits indefinitely until the other user COMMITs.

Your session waits for 10 seconds, and then returns control to your bloc
k so that it can continue to execute. (*)

Your block fails because you should have coded: FOR UPDATE WAIT (10);

Correct

4. You want to fetch rows from the EMPLOYEES table. You wa


nt to lock the fetched rows, to prevent other users from updating them. You decl
are the following cursor: CURSOR emp_curs IS SELECT employee_id, last_name, sala
ry FROM employees -- Line A -- ; What should you code at Line A? Mark for
Review
(1) Points

FOR LOCK

FOR UPDATE OF employees

FOR UPDATE (*)

FOR UPDATE (employees)

Correct

5. If the rows you attempt to reserve using FOR UPDATE hav


e already been locked by another session and you use the NOWAIT option, what is
the outcome? Mark for Review
(1) Points

The block executes successfully with no errors.

The server will wait until the locks have been released by the other use
r.
An Oracle server error occurs. (*)

Your rows will override the other users' lock and your block will execut
e successfully.

Correct

6. You declare a cursor as a join of two tables: CURSOR em


p_dept_curs IS SELECT last_name, salary, department_name FROM employees e, depar
tments d WHERE e.department_id = d.department_id -- Point A -- ; You want to loc
k fetched rows from EMPLOYEES, but NOT lock fetched rows from DEPARTMENTS. Which
of the following is correct at Point A? Mark for Review
(1) Points

FOR UPDATE

FOR UPDATE of salary (*)

FOR UPDATE OF employees

FOR UPDATE (last_name)

Incorrect. Refer to Section 5 Lesson 2.

7. What is the difference between the following two blocks


of code?
--Block A
DECLARE
CURSOR emp_cursor IS
SELECT employee_id, last_name
FROM employees
WHERE department_id = 80
FOR UPDATE OF salary;
--Block B
DECLARE
CURSOR emp_cursor IS
SELECT employee_id, last_name
FROM employees
WHERE department_id = 80
FOR UPDATE OF salary
NOWAIT;
Mark for Review
(1) Points

There is no difference; the programs behave exactly the same way.


In Block A, the program waits indefinitely until the rows are available.
In Block B, the program returns control immediately so that it can do other wor
k. (*)

In Block A, the program waits indefinitely until the rows are available.
In Block B, control is returned to your program after 5 seconds so that it can
do other work.

Correct
1. Which of the following is NOT allowed when using multiple cursors with
parameters? Mark for Review
(1) Points

You cannot use cursor FOR loops.

You cannot declare the cursors FOR UPDATE.

You cannot declare a cursor based on a join.

You cannot OPEN more than one cursor at the same time.

None of the above, they are all allowed. (*)

Correct

2. Assume that table BIGDEPTS contains 100 rows, and table


BIGEMPS contains 1000 rows, with 10 employees in each department. Consider the
following code:
DECLARE
CURSOR bigdept_cur IS
SELECT * FROM bigdepts;
CURSOR bigemp_cur IS
SELECT * FROM bigemps;
BEGIN
FOR dept_rec IN bigdept_cur LOOP
DBMS_OUTPUT.PUT_LINE (dept_rec.department_name);
FOR emp_rec IN bigemp_cur LOOP
IF emp_rec.department_id=dept_rec.department_id
THEN DBMS_OUTPUT.PUT_LINE (emp_rec.last_name);
END IF;
END LOOP;
END LOOP;
END;
Why is this code inefficient?
Mark for Review
(1) Points
It locks both tables unnecessarily.

It is using two cursors when one cursor is enough.

It is doing a Cartesian Product, joining every employee with every depar


tment and displaying 1100 lines of output.

It reads 1000 employee rows every time BIGEMP_CUR is OPENed, and then ig
nores 990 of them. (*)

It is using cursor FOR loops, which are less efficient than OPENing and
CLOSEing the cursors explicitly.

Correct

3. Examine the following code:


DECLARE
CURSOR region_cur IS
SELECT * FROM wf_world_regions;
v_region_rec region_cur%ROWTYPE;
CURSOR country_cur (p_region_id NUMBER) IS
SELECT * FROM wf_countries
WHERE region_id = p_region_id;
v_country_rec country_cur%ROWTYPE;
BEGIN
OPEN region_cur;
LOOP
FETCH region_cur INTO v_region_rec;
EXIT WHEN region_cur%NOTFOUND;
DBMS_OUTPUT.PUT_LINE
(v_region_rec.region_name);
-- Line A --
LOOP
FETCH country_cur INTO v_country_rec;
EXIT WHEN country_cur%NOTFOUND;
......
What would you code at Line A?
Mark for Review
(1) Points

OPEN country_cur (p_region_id);

OPEN country_cur (wf_world_regions.region_id);

OPEN country_cur (v_region_rec.region_id); (*)


OPEN country_cur (region_cur.region_id);

OPEN country_cur;

Incorrect. Refer to Section 5 Lesson 6.

4. Which of the following is a good reason to use two curs


ors in a single PL/SQL block? Mark for Review
(1) Points

To allow one cursor to be opened twice at the same time.

When two tables are related to each other (often by a foreign key) and w
e want to produce a multilevel report using data from both tables. (*)

To allow rows to be locked as they are FETCHed.

To speed up the execution of the PL/SQL block.

It is the only way to declare a cursor with a parameter.

Incorrect. Refer to Section 5 Lesson 6.

5. You want to produce a report which displays each depart


ment and (immediately after each department) a list of employees who work in tha
t department. You declare a DEPARTMENTS cursor as:
CURSOR dept_curs IS
SELECT * FROM departments
ORDER BY department_id;
How could you declare the EMPLOYEES cursor? (Choose two).
Mark for Review
(1) Points
(Choose all correct answers)

CURSOR emp_curs IS SELECT * FROM employees;

CURSOR emp_curs (p_dept_id NUMBER) IS SELECT * FROM employees WHERE depa


rtment_id = p_dept_id; (*)

CURSOR emp_curs IS SELECT * FROM employees ORDER BY department_id;


CURSOR emp_curs (p_dept_id departments.department_id%TYPE) IS SELECT * F
ROM employees WHERE department_id = p_dept_id; (*)

CURSOR emp_curs IS SELECT * FROM employees WHERE department_id = departm


ents.department_id;

Incorrect. Refer to Section 5 Lesson 6.

6. Assume your schema contains 25 tables. How many explici


t cursors can you declare and use within a single PL/SQL block? Mark for Review
(1) Points

Only one.

As many as you need - there is no limit. (*)

A maximum of three.

As many as you need, but only one of them can be open at any time.

A maximum of 25 (one for each table in your schema).

Correct

You might also like