KEMBAR78
PL/SQL Explicit Cursors Quiz | PDF | Pl/Sql | Control Flow
0% found this document useful (0 votes)
563 views16 pages

PL/SQL Explicit Cursors Quiz

This document provides a quiz on explicit cursors in PL/SQL. It consists of multiple choice questions testing various aspects of declaring and using explicit cursors, including cursor attributes. The quiz provides feedback for each answer selected and indicates the correct answer with an asterisk.

Uploaded by

ssmile
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
563 views16 pages

PL/SQL Explicit Cursors Quiz

This document provides a quiz on explicit cursors in PL/SQL. It consists of multiple choice questions testing various aspects of declaring and using explicit cursors, including cursor attributes. The quiz provides feedback for each answer selected and indicates the correct answer with an asterisk.

Uploaded by

ssmile
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 16

Test: Quiz: Introductionto Explicit Cursors

Review your answers, feedback, and question scores below. An asterisk (*) indicates a correct answer.
Section 1
(Answer all questions in this section)
1. Which one of the following explicit cursor declarations is NOT valid?

Mark for Review


(1) Points

CURSOR country_curs IS SELECT country_name, region_name FROM


wf_countries c, wf_world_regions r WHERE c.region_id = r.region_id;
CURSOR country_curs IS SELECT country_name INTO v_country_name FROM
wf_countries; (*)
CURSOR country_curs IS SELECT country_name FROM wf_countries ORDER BY
population DESC;
CURSOR country_curs IS SELECT country_name FROM wf_countries WHERE
region_id IN (SELECT region_id FROM wf_world_regions WHERE
LOWER(region_name) LIKE '%asia%');
Correct
2. When must you declare and use an explicit cursor?

Mark for Review


(1) Points

You need to UPDATE more than one row in a table.


You want to use a MERGE statement.
You need to SELECT more than one row from a table. (*)
You want to be able to ROLLBACK a transaction if needed.
Correct
3. You have declared a cursor EMP_CURSOR to select many rows from the EMPLOYEES
table. The following five statements will be in the executable section:
A
B
C
D
E

Mark for Review


(1) Points

FETCH emp_cursor INTO v_empno,v_last_name;


OPEN emp_cursor;
END LOOP;
CLOSE emp_cursor;
LOOP

In which order should you code these statements?


B, E, A, C, D (*)
E, B, A, C, D
B, E, A, D, C
B, A, E, D, C
Correct
4. Which one of the following statements is NOT true?

You can use ORDER BY when declaring an explicit cursor.

Mark for Review


(1) Points

You can not use an INTO clause when declaring an explicit cursor.
An explicit cursor can select from only one table. No joins are allowed. (*)
An explicit cursor must be DECLAREd before it can be OPENed.
Correct
5. One (and only one) employee has LAST_NAME = 'Grant'. You need to code:
SELECT ... FROM employees WHERE last_name = 'Grant';

Mark for Review


(1) Points

Which type of cursor should you use, and why?


An implicit cursor, because there is only one 'Grant'.
An implicit cursor, because SELECT is a SQL statement and implicit cursors are
always called "SQL".
An explicit cursor, because there could be more than one 'Grant' in the future. (*)
An explicit cursor, because you can use an implicit cursor only for DML
statements.
Correct
6. Examine the following code:
DECLARE
CURSOR dept_curs IS SELECT department_name FROM departments;
v_dept_name departments.department_name%TYPE;
BEGIN
OPEN dept_curs;
LOOP
FETCH dept_curs INTO v_dept_name;
DBMS_OUTPUT.PUT_LINE(v_dept_name);
EXIT WHEN dept_curs%NOTFOUND;
END LOOP;
CLOSE dept_curs;
END;

Mark for Review


(1) Points

There are 10 rows in the DEPARTMENTS table. What will happen when this code is
executed?
10 rows will be displayed.
10 rows will be displayed, followed by a row of NULL values.
The last row will be displayed twice. (*)
A NO_DATA_FOUND exception will be raised.
The loop will execute for ever; the same 10 rows will be displayed over and over
again.
Correct
7. You must make sure you have the same number of variables in your INTO statement
as you have in your SELECT list. True or False?
True (*)
False
Correct

Mark for Review


(1) Points

8. What is wrong with the following code?


DECLARE
CURSOR dept_curs IS SELECT department_name FROM departments;
v_dept_name departments.department_name%TYPE;
BEGIN
OPEN dept_curs;
LOOP
FETCH dept_curs INTO v_dept_name;
EXIT WHEN dept_curs%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(v_dept_name);
CLOSE dept_curs;
END LOOP;
END;

Mark for Review


(1) Points

Nothing is wrong, all the rows will be FETCHed and displayed.


The OPEN statement should be inside the loop.
The EXIT WHEN ... statement should be coded outside the loop.
The CLOSE statement should be coded after END LOOP; (*)
The loop should be a WHILE loop, not a basic loop.
Correct
9. What is wrong with the following code?
DECLARE
CURSOR emp_curs IS SELECT last_name, salary FROM employees;
v_last_name employees.last_name%TYPE;
v_salary employees.salary%TYPE;
BEGIN
FETCH emp_curs INTO v_last_name, v_salary;
OPEN emp_curs;
FETCH emp_curs INTO v_last_name, v_salary;
CLOSE emp_curs;
END;

Mark for Review


(1) Points

When FETCHing more than one row, you MUST use a loop.
The cursor declaration does not include a WHERE condition.
The cursor declaration does not include an INTO clause.
The first row is FETCHed before the cursor is OPENed. (*)
Correct
10. Which of the following best describes the difference between implicit and explicit
cursors?
Implicit cursors are used for SELECT statements, while explicit cursors are used
for DML statements.
Implicit cursor are named by the PL/SQL programmer, while explicit cursors are
always named SQL.
Implicit cursors are defined automatically by Oracle, while explicit cursors must
be declared by the PL/SQL programmer. (*)
Implicit cursors store rows on disk, while explicit cursors store rows in memory.

Mark for Review


(1) Points

Correct
11. Which statement correctly places the employee id and last name into the stated
variables?

Mark for Review


(1) Points

DECLARE
CURSOR emp_cursor IS
SELECT employee_id, last_name FROM employees
WHERE department_id = 30;
v_empno employees.employee_id%TYPE;
v_lname employees.last_name%TYPE;
BEGIN
OPEN emp_cursor;
-- Point A
...
GET emp_cursor INTO v_empno, v_lname;
FETCH emp_cursor INTO v_empno, v_lname; (*)
GET emp_cursor.employee_id, emp_cursor.last_name INTO v_empno, v_lname;
FETCH emp_cursor.employee_id, emp_cursor.last_name INTO v_empno,
v_lname;
Correct
12. You cannot OPEN or CLOSE an implicit cursor. Why not?

Mark for Review


(1) Points

Because an implicit cursor is always called SQL.


Because an implicit cursor is OPENed and CLOSEd automatically by Oracle. (*)
Correct
13. You execute the following code:
DECLARE
CURSOR emp_curs IS SELECT last_name FROM employees;
v_last_name employees.last_name%TYPE;
BEGIN
OPEN emp_curs;
LOOP -- Point A
FETCH emp_curs INTO v_last_name;
EXIT WHEN emp_curs%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(v_last_name);
END LOOP;
CLOSE emp_curs;
END;
At Point A (after you have OPENed the cursor) another user updates an employee's
last_name from 'Smith' to 'Jones' and immediately COMMITs.
When your block FETCHes this row, which value will be fetched and displayed?
1
Smith (*)

Mark for Review


(1) Points

Jones
Smith and Jones (the row will be fetched twice)
An INVALID_CURSOR exception will be raised when you try to FETCH the row.
Correct
14. There are 8 countries in REGION_ID 13 (Central America). What will happen when the
following code is executed?

Mark for Review


(1) Points

DECLARE
CURSOR country_curs IS SELECT country_name FROM wf_countries
WHERE region_id = 13;
v_country_name wf_countries.country_name%TYPE;
BEGIN
OPEN country_curs;
WHILE country_curs%FOUND
LOOP
FETCH country_curs INTO v_country_name;
DBMS_OUTPUT.PUT_LINE(v_country_name);
END LOOP;
CLOSE country_curs;
END;
Eight rows will be fetched and displayed successfully.
The last seven rows will be fetched and displayed.
The block will execute, but no rows will be displayed. (*)
The block will fail because you can not use a WHILE loop with an explicit cursor.
None of the above.
Correct

Test: Quiz: Using Explicit Cursor Attributes


Review your answers, feedback, and question scores below. An asterisk (*) indicates a correct answer.
Section 1
(Answer all questions in this section)
1. How must you reference one field which is part of a PL/SQL record?

field_name.record_name
record_name.field_name (*)
record_name(field_name)
field_name OF record_name
It cannot be done.
Correct

Mark for Review


(1) Points

2. You can reference explicit cursor attributes directly in a SQL statement. True or False?

Mark for Review


(1) Points

True
False (*)
Incorrect. Refer to Section 5 Lesson 2.
3. 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;

Mark for Review


(1) Points

You want to display the id and name of each FETCHed country. What would you code at
Line A?
DBMS_OUTPUT.PUT_LINE(country_id || ' ' || country_name);
DBMS_OUTPUT.PUT_LINE(v_country(country_id) || ' ' ||
v_country(country_name));
DBMS_OUTPUT.PUT_LINE(country_curs.country_id || ' ' ||
country_curs.country_name);
DBMS_OUTPUT.PUT_LINE(v_country.country_id || ' ' || v_country.country_name);
(*)
Correct
4. 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
display only the first 25 rows.
How would you exit from the FETCH loop?
EXIT WHEN country_curs%FOUND(25);
EXIT WHEN country_curs%ROWCOUNT > 25; (*)
EXIT WHEN ROWCOUNT > 25;
WHEN country_curs > 25 THEN EXIT; END IF;

Mark for Review


(1) Points

Correct
5. Which of the following explicit cursor attributes evaluates to TRUE if the most recent
FETCH returns a row?

Mark for Review


(1) Points

%ISOPEN
%NOTFOUND
%FOUND (*)
%ROWCOUNT
Correct
6. 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;

Mark for Review


(1) Points

How many fields does V_DEPT_LOC contain?


Two, because the cursor joins two tables
Four
Three (*)
None
Correct
7. 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?
Scalar
Record (*)
Cursor
Row
Correct

Mark for Review


(1) Points

Test: Quiz: Cursor FOR Loops


Review your answers, feedback, and question scores below. An asterisk (*) indicates a correct answer.
Section 1
(Answer all questions in this section)
1. 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;

Mark for Review


(1) Points

To display the salary of an employee, what code should you write at Point A?
emp_record.salary (*)
emp_cursor.salary
employees.salary
emp_record.employees.salary
TO_CHAR(salary)
Correct
2. Which of the following is a benefit of using a cursor FOR 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.
Correct
3. 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 ...
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.

Mark for Review


(1) Points

Correct
4. Which one of the following is a valid cursor FOR loop with 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) LOOP
... (*)
None of the above.
Correct
5. What is the DISadvantage of using a cursor FOR loop with 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
6. A cursor FOR loop using a subquery can extensively shorten code length when
compared to an explicit cursor declaration. True or False?

Mark for Review


(1) Points

True (*)
False
Correct
7. 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?
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

Mark for Review


(1) Points

Test: Quiz: Cursors for Parameters


Review your answers, feedback, and question scores below. An asterisk (*) indicates a correct answer.
Section 1
(Answer all questions in this section)
1. 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
2. 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;

Mark for Review


(1) Points

Which of the following will correctly open the cursor?


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
3. You want to use explicit cursors to fetch and display all 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 many 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
4. 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
5. 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 --);
....

Mark for Review


(1) Points

You want to open the cursor, passing value 50 to the parameter. Which of the following
are correct at Point A?
50
v_deptid
100 / 2
All of the above. (*)
Correct

Test: Quiz: Using Cursors for Update


Review your answers, feedback, and question scores below. An asterisk (*) indicates a correct answer.
Section 1
(Answer all questions in this section)
1. If the rows you attempt to reserve using FOR UPDATE have 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 user.
An Oracle server error occurs. (*)
Your rows will override the other users' lock and your block will execute
successfully.
Correct
2. You declare a cursor as a join of two tables:
CURSOR emp_dept_curs IS
SELECT last_name, salary, department_name
FROM employees e, departments d

Mark for Review


(1) Points

WHERE e.department_id = d.department_id


-- Point A -- ;
You want to lock fetched rows from EMPLOYEES, but NOT lock fetched rows from
DEPARTMENTS.
Which of the following is correct at Point A?
FOR UPDATE
FOR UPDATE of salary (*)
FOR UPDATE OF employees
FOR UPDATE (last_name)
Correct
3. You have declared a cursor as SELECT .... FOR UPDATE; You 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.
Correct
4. 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;
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 work. (*)
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

Mark for Review


(1) Points

5. You have declared the following cursor:


CURSOR country_curs IS
SELECT country_id, country_name
FROM wf_countries
FOR UPDATE WAIT 10;

Mark for Review


(1) Points

Another user updates a row in WF_COUNTRIES but does not COMMIT the update. What
will happen when you OPEN country_curs; ?
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 block so that it
can continue to execute. (*)
Your block fails because you should have coded: FOR UPDATE WAIT (10);
Correct
6. You want to fetch rows from the EMPLOYEES table. You want to lock the fetched rows,
to prevent other users from updating them. You declare the following cursor:

Mark for Review


(1) Points

CURSOR emp_curs IS
SELECT employee_id, last_name, salary
FROM employees
-- Line A -- ;
What should you code at Line A?
What should you code at Line A?
FOR LOCK
FOR UPDATE OF employees
FOR UPDATE (*)
FOR UPDATE (employees)
Correct
7. When can we use the WHERE CURRENT OF clause?

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

Mark for Review


(1) Points

Test: Quiz: Using Multiple Cursors


Review your answers, feedback, and question scores below. An asterisk (*) indicates a correct answer.
Section 1
(Answer all questions in this section)
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 your schema contains 25 tables. How many explicit 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
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;
Correct
4. Assume that table BIGDEPTS contains 100 rows, and table BIGEMPS contains 1000
rows, with 10 employees in each department. Consider the following code:

Mark for Review


(1) Points

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?
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 department and
displaying 1100 lines of output.
It reads 1000 employee rows every time BIGEMP_CUR is OPENed, and then
ignores 990 of them. (*)
It is using cursor FOR loops, which are less efficient than OPENing and CLOSEing
the cursors explicitly.
Correct
5. Which of the following is a good reason to use two cursors in a single PL/SQL block?

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 we 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.
Correct

Mark for Review


(1) Points

6. You want to produce a report which displays each department and (immediately after
each department) a list of employees who work in that 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).
(Choose all correct answers)
CURSOR emp_curs IS
SELECT * FROM employees;
CURSOR emp_curs (p_dept_id NUMBER) IS
SELECT * FROM employees
WHERE department_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 * FROM employees
WHERE department_id = p_dept_id;
(*)
CURSOR emp_curs IS
SELECT * FROM employees
WHERE department_id = departments.department_id;
Correct

Mark for Review


(1) Points

You might also like