1. What is missing from the following cursor declaration?
CURSOR emp_curs
IS
SELECT * FROM departments
WHERE location_id = p_loc_id;
Mark for Review
(1) Points
A parameter is missing. The parameter should be coded as: (p_loc_id NUMBER) (*)
Nothing is wrong; the cursor declaration is correct.
The declaration is invalid. You cannot reference a cursor parameter in a WHERE clause.
A parameter is missing. The parameter should be coded as: (p_loc_id IN NUMBER)
Correct Correct
2. 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
20 cursors, in case an extra row is inserted into WF_WORLD_REGIONS later.
19 cursors in 19 PL/SQL blocks (one in each block).
19 cursors, all in the same PL/SQL block.
None of the these.
One cursor with a parameter in the WHERE clause. (*)
Correct Correct
3. You have declared the following cursor: CURSOR country_curs IS
SELECT country_id, country_name
FROM wf_countries
FOR UPDATE WAIT 10; Another user updates a row in WF_COUNTRIES but does not COMMIT the update. What will happen when you OPEN country_curs; ? Mark for Review
(1) Points
A LOCKED_ROWS exception is raised immediately.
Your block fails because you should have coded: FOR UPDATE WAIT (10);
Your session waits for 10 seconds, and then returns control to your block so that it can continue to execute. (*)
Your session waits indefinitely until the other user COMMITs.
The other user's transaction is automatically rolled back.
Correct Correct
4. 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
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? Mark for Review
(1) Points
FOR UPDATE
FOR UPDATE of salary (*)
FOR UPDATE (last_name)
FOR UPDATE OF employees
Correct Correct
5. 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 (v_region_rec.region_id); (*)
OPEN country_cur (p_region_id);
OPEN country_cur (wf_world_regions.region_id);
OPEN country_cur;
OPEN country_cur (region_cur.region_id);
Correct Correct
6. 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 reads 1000 employee rows every time BIGEMP_CUR is OPENed, and then ignores 990 of them. (*)
It is doing a Cartesian Product, joining every employee with every department and displaying 1100 lines of output.
It is using cursor FOR loops, which are less efficient than OPENing and CLOSEing the cursors explicitly.
It is using two cursors when one cursor is enough.
It locks both tables unnecessarily.
Correct Correct
7. How must you reference one field which is part of a PL/SQL record? Mark for Review
(1) Points
It cannot be done.
field_name.record_name
field_name OF record_name
record_name(field_name)
record_name.field_name (*)
Correct Correct
8. Which of the following statements about the %ISOPEN cursor attribute is true? Mark for Review
(1) Points
You can issue the %ISOPEN cursor attribute only when more than one record is returned.
You can issue the %ISOPEN cursor attribute only when a cursor is open.
If a cursor is open, then the value of %ISOPEN is false.
You can issue the %ISOPEN cursor attribute when a cursor is open or closed. (*)
Correct Correct
9. Which of the following explicit cursor attributes evaluates to TRUE if the most recent FETCH returns a row? Mark for Review
(1) Points
%FOUND (*)
%ROWCOUNT
%NOTFOUND
%ROWTYPE
Correct Correct
10. A cursor FOR loop using a subquery can shorten code length when compared to an explicit cursor declaration. True or False? Mark for Review
(1) Points
True (*)
False
Correct Correct
11. There are no employees in department_id 75.
Which of the following is NOT a valid cursor FOR loop with a subquery? Mark for Review
(1) Points
FOR emp_rec IN
(SELECT last_name, salary FROM employees ORDER BY last_name) LOOP ...
FOR emp_rec IN
(SELECT * FROM employees WHERE department_id = 75) LOOP ...
FOR emp_rec IN
(SELECT last_name, salary FROM employees) LOOP ...
None of these. They are all valid. (*)
FOR emp_rec IN
(SELECT * FROM employees) LOOP ...
Correct Correct
12. When using a cursor FOR loop, OPEN, CLOSE, and FETCH statements should not be explicitly coded. True or False? Mark for Review
(1) Points
True (*)
False
Correct Correct
13. Which of these constructs can be used to fetch multiple rows from a cursor's active set? Mark for Review
(1) Points
An IF .... ELSE statement
A CASE statement
A basic loop which includes FETCH and EXIT WHEN statements (*)
A basic loop which includes OPEN, FETCH, and CLOSE statements
Correct Correct
14. Which of the following best describes the difference between implicit and explicit cursors? Mark for Review
(1) Points
Implicit cursor are named by the PL/SQL programmer, while explicit cursors are always named SQL.
Implicit cursors store rows on disk, while explicit cursors store rows in memory.
Implicit cursors are used for SELECT statements, while explicit cursors are used for DML statements.
Implicit cursors are defined automatically by Oracle, while explicit cursors must be declared by the PL/SQL programmer. (*)
Correct Correct
15. There are 8 countries in REGION_ID 13 (Central America). What will happen when the following code is executed?
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;
Mark for Review
(1) Points
The block will execute, but no rows will be displayed. (*)
None of the these.
The block will fail because you can not use a WHILE loop with an explicit cursor.
Eight rows will be fetched and displayed successfully.
The last seven rows will be fetched and displayed.
Correct Correct
16. Which one of the following explicit cursor declarations is NOT valid? Mark for Review
(1) Points
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, region_name FROM wf_countries c, wf_world_regions r WHERE c.region_id = r.region_id;
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 Correct
Section 6
(Answer all questions in this section)
17. Which of the following methods can be used to reference elements of an INDEX BY table? (Choose three.) Mark for Review
(1) Points
(Choose all correct answers)
EXISTS (*)
PREVIOUS
DROP
COUNT (*)
FIRST (*)
Correct Correct
18. You can store a whole record in a single variable using %ROWTYPE or by creating your own record structure as a type and then declaring a variable of that type. Mark for Review
(1) Points
True (*)
False
Correct Correct
Section 7
(Answer all questions in this section)
19. How can you retrieve the error code and error message of any Oracle Server exception? Mark for Review
(1) Points
By using the functions SQLCODE and SQLERRM (*)
By defining an EXCEPTION variable and using PRAGMA EXCEPTION_INIT
By using RAISE_APPLICATION_ERROR
By using the functions SQLCODE and SQLERR
Correct Correct
20. Which one of the following events would implicitly raise an exception? Mark for Review
(1) Points
A SELECT statement returns exactly one row.
An UPDATE statement modifies no rows.
A database constraint is violated. (*)
The PL/SQL programmer mis-spells the word BEGIN as BEGAN.
Correct Correct
21. Which of the following best describes a user-defined exception? Mark for Review
(1) Points
An error which is not automatically raised by the Oracle server (*)
A predefined Oracle Server error such as NO_DATA_FOUND
Any error which has an Oracle error number of the form ORA-nnnnn
A non-predefined Oracle Server error such as ORA-01400
Correct Correct
22. Non-predefined Oracle Server errors (associated with Oracle error numbers by PRAGMA EXCEPTION_INIT) can be declared and raised in inner blocks and handled in outer blocks. True or False? Mark for Review
(1) Points
True
False (*)
Correct Correct
23. What will happen when the following code is executed?
DECLARE
e_excep1 EXCEPTION;
e_excep2 EXCEPTION;
BEGIN
RAISE e_excep1;
EXCEPTION
WHEN e_excep1 THEN
BEGIN
RAISE e_excep2;
END;
END;
Mark for Review
(1) Points
It will fail to compile because you cannot declare more than one exception in the same block.
It will fail to compile because you cannot have a subblock inside an exception section.
It will fail to compile because e_excep1 is out of scope in the subblock.
It will compile successfully and return an unhandled e_excep2 to the calling environment. (*)
Correct Correct
24. Which of the following EXCEPTION sections is constructed correctly? (Choose three.) Mark for Review
(1) Points
(Choose all correct answers)
EXCEPTION
WHEN NO_DATA_FOUND THEN statement_1;
WHEN OTHERS THEN statement_2;
END;
(*)
EXCEPTION
WHEN OTHERS THEN statement_1;
WHEN NO_DATA_FOUND THEN statement_2;
END;
EXCEPTION
WHEN NO_DATA_FOUND THEN statement_1;
WHEN NO_DATA_FOUND THEN statement_2;
WHEN OTHERS THEN statement_3;
END;
EXCEPTION
WHEN TOO_MANY_ROWS THEN statement_1;
END;
(*)
EXCEPTION
WHEN OTHERS THEN statement_1;
END;
(*)
Incorrect Incorrect. Refer to Section 7 Lesson 1.
25. Which of these exceptions can be handled by an EXCEPTION section in a PL/SQL block? Mark for Review
(1) Points
A SELECT statement returns more than one row.
None of these.
Any other kind of exception that can occur within the block
A SELECT statement returns no rows.
All of these. (*)
Correct Correct
While a PL/SQL block is executing, more than one exception can occur at the same time. True or False? Mark for Review
(1) Points
TRUE
FALSE (*)
Correct Correct
27. No employees are in department_id 99. What output will be displayed when the following code is executed?
DECLARE
v_count NUMBER;
BEGIN
SELECT COUNT(*) INTO v_count
FROM employees WHERE department_id = 99;
IF v_count = 0 THEN
RAISE NO_DATA_FOUND;
DBMS_OUTPUT.PUT_LINE('No employees found');
END IF;
EXCEPTION
WHEN NO_DATA_FOUND THEN
DBMS_OUTPUT.PUT_LINE('Department 99 is empty');
END;
Mark for Review
(1) Points
No employees found
No employees found Department 99 is empty
The block will fail because you cannot explicitly RAISE a predefined Oracle Server error such as NO_DATA_FOUND
Department 99 is empty (*)
Correct Correct
28. The following three steps must be performed to use a user-defined exception: - Raise the exception - Handle the exception - Declare the exception In what sequence must these steps be performed? Mark for Review
(1) Points
Raise, Handle, Declare
Handle, Raise, Declare
Declare, Raise, Handle (*)
The steps can be performed in any order.
Correct Correct
29. Department-id 99 does not exist. What will be displayed when the following code is executed?
DECLARE
v_deptname departments.department_name%TYPE;
BEGIN
SELECT department_name INTO v_deptname
FROM departments WHERE department_id = 99;
EXCEPTION
WHEN NO_DATA_FOUND THEN
RAISE_APPLICATION_ERROR(-20201,'Department does not exist');
END;
Mark for Review
(1) Points
ORA-01403: No Data Found ORA-20201: Department does not exist
ORA-20201: Department does not exist (*)
None of these.
ORA-01403: No Data Found
Correct Correct
Section 8
(Answer all questions in this section)
30. Which of the following keywords MUST be included in every PL/SQL procedure definition? (Choose two.) Mark for Review
(1) Points
(Choose all correct answers)
END (*)
REPLACE
BEGIN (*)
EXCEPTION
DECLARE
Correct Correct
31. A programmer wants to create a PL/SQL procedure named MY_PROC. What will happen when the following code is executed?
CREATE OR REPLACE PROCEDURE my_proc IS
v_empid employees.empid%TYPE;
BEGIN
SELECT employee_id INTO v_empid FROM employees
WHERE region_id = 999;
DBMS_OUTPUT.PUT_LINE('The salary is: ' || v_salary);
Mark for Review
(1) Points
The statement will raise a NO_DATA_FOUND exception because region_id 999 does not exist.
The statement will fail because the last line of code should be END my_proc; (*)
The statement will fail because you cannot declare variables such as v_empid inside a procedure.
Correct Correct
32. The following are the steps involved in creating, and later modifying and re-creating, a PL/SQL procedure in Application Express. In what sequence should these steps be performed?
Retrieve the saved code from "Saved SQL" in SQL Commands
Execute the code to create the procedure
Execute the code to re-create the procedure
Click on the "Save" button and save the procedure code
Modify the code in the SQL Commands window
Type the procedure code in the SQL Commands window
Mark for Review
(1) Points
F,B,D,A,E,C (*)
E,D,F,C,A,B
F,B,C,D,E,A
F,B,D,E,A,C
F,C,A,B,E,D
Correct Correct
33. You have created procedure MYPROC with a single parameter PARM1 NUMBER. Now you want to add a second parameter to the procedure. Which of the following will change the procedure successfully? Mark for Review
(1) Points
REPLACE PROCEDURE myproc
(parm1 NUMBER, parm2 NUMBER)
IS
BEGIN ...
CREATE OR REPLACE PROCEDURE myproc
(parm1 NUMBER, parm2 NUMBER)
IS
BEGIN ... (*)
The procedure cannot be modified. Once a procedure has been created, the number of parameters cannot be changed.
ALTER PROCEDURE myproc ADD (parm2 NUMBER);
CREATE OR REPLACE PROCEDURE myproc
(parm1 NUMBER, parm2 NUMBER);
(You do not need to repeat the detailed code of the procedure, only the header)
Correct Correct
34. A procedure will execute faster if it has at least one parameter. Mark for Review
(1) Points
True
False (*)
Correct Correct
35. Suppose you set up a parameter with an explicit IN mode. What is true about that parameter? Mark for Review
(1) Points
It must be the same type as the matching OUT parameter.
It must have a DEFAULT value.
It inherits its type from the matching OUT parameter.
It cannot have a DEFAULT value.
It acts like a constant (its value cannot be changed inside the subprogram). (*)
Correct Correct
36. What are the types of parameter modes? Mark for Review
(1) Points
LOCAL, GLOBAL, BOTH
IN, OUT, IN OUT (*)
CHARACTER, NUMBER, DATE, BOOLEAN
CONSTANT, VARIABLE, DEFAULT
Correct Correct
Section 9
(Answer all questions in this section)
37. The following code shows the dependencies between three procedures:
CREATE PROCEDURE parent
IS BEGIN
child1;
child2;
END parent;
You now try to execute:
DROP PROCEDURE child2;
What happens?
Mark for Review
(1) Points
You cannot drop CHILD2 because PARENT is dependent on it.
CHILD2 is dropped successfully. PARENT is marked INVALID, but CHILD1 is still valid. (*)
The database automatically drops CHILD1 as well.
The database automatically drops PARENT as well.
CHILD2 is dropped successfully. PARENT and CHILD1 are both marked INVALID.
Correct Correct
38. Which Data Dictionary view can be used to display the detailed code of a procedure in your schema? Mark for Review
(1) Points
USER_SUBPROGRAMS
USER_OBJECTS
None of these
USER_SOURCE (*)
USER_PROCEDURES
Correct Correct
39. You want to create a function which can be used in a SQL statement. Which one of the following can be coded within your function? Mark for Review
(1) Points
An OUT parameter
COMMIT;
One or more IN parameters (*)
RETURN BOOLEAN
Correct Correct
40. The following function has been created:
CREATE OR REPLACE FUNCTION upd_dept
(p_dept_id IN departments.department_id%TYPE)
RETURN NUMBER IS
BEGIN
UPDATE departments
SET department_name = 'Accounting'
WHERE department_id = p_dept_id;
RETURN p_dept_id;
END;
Which of the following will execute successfully?
Mark for Review
(1) Points
DELETE FROM departments
WHERE department_id = upd_dept(department_id);
SELECT upd_dept(80)
FROM dual;
DELETE FROM employees
WHERE department_id = upd_dept(80);
(*)
SELECT upd_dept(department_id)
FROM employees;
41. Which of the following is a legal location for a function call in a SQL statement? (Choose 3) Mark for Review
(1) Points
(Choose all correct answers)
VALUES clause of an INSERT statement (*)
WHERE clause in a DELETE statement (*)
CREATE TABLE statement
The ORDER BY and GROUP BY clauses of a query (*)
Correct Correct
42. Why will this function not compile correctly?
CREATE FUNCTION bad_one
IS BEGIN
RETURN NULL;
END bad_one;
Mark for Review
(1) Points
The body of the function must contain at least one executable statement (as well as RETURN).
You must declare the type of the RETURN before the IS. (*)
You must code CREATE OR REPLACE, not CREATE.
You cannot RETURN a NULL.
You must have at least one IN parameter.
Correct Correct
43. Based on the following function definition:
Create function annual_comp
(sal employees.salary%type,
comm_pct IN employees.commission%type)
...
Which one of the following is an incorrect call for annual_comp?
Mark for Review
(1) Points
Execute dbms_output.put_line(annual_comp (1000,.2));
Select employee_id, annual_comp(salary)
from employees; (*)
Declare
Ann_comp number (6,2);
Begin
...
Ann_comp := annual_comp(1000,.2);
...
End;
Select employee_id, annual_comp(salary, commission_pct)
from employees;
Correct Correct
44. Which of the following is found in a function and not a procedure? Mark for Review
(1) Points
IN parameters
An exception section
Return statement in the header (*)
Local variables in the IS/AS section
Correct Correct
45. You want to see the names of all the columns in a table in your schema. You want to query the Dictionary instead of using the DESCRIBE command. Which Dictionary view should you query? Mark for Review
(1) Points
USER_TAB_COLS (*)
USER_COLUMNS
USER_TABLES
USER_OBJECTS
Incorrect Incorrect. Refer to Section 9 Lesson 3.
46. A user executes the following statement:
CREATE INDEX fn_index ON employees(first_name);
What output will the following statement now display:
SELECT index_name
FROM user_indexes
WHERE index_name LIKE 'fn%';
Mark for Review
(1) Points
No output will be displayed (*)
FN_INDEX
fn_index FN_INDEX
fn_index
Correct Correct
47. How do you specify that you want a procedure MYPROCA to use "Definer's Rights"? Mark for Review
(1) Points
ALTER PROCEDURE myproca TO DEFINER;
CREATE OR REPLACE PROCEDURE myproca
AUTHID OWNER IS...
GRANT DEFINER TO myprocA;
CREATE OR REPLACE PROCEDURE myproca
AUTHID CURRENT_USER IS...
Definer's Rights are the default, therefore no extra code or commands are needed. (*)
Correct Correct
48. Which statement is true regarding the following subprogram?
PROCEDURE at_proc IS
PRAGMA AUTONOMOUS_TRANSACTION;
dept_id NUMBER := 90;
BEGIN
UPDATE ...
INSERT ...
END at_proc;
Mark for Review
(1) Points
The subprogram will fail because the RETURN is not specified.
The subprogram's success depends on the calling program.
The subprogram's success is independent of the calling program. (*)
The subprogram cannot do a COMMIT.
Correct Correct
49. User COLLEEN owns an EMPLOYEES table and wants to allow user AYSE to create indexes on the table. Which object privilege must Colleen grant to Ayse? Mark for Review
(1) Points
ALTER on EMPLOYEES
SELECT on EMPLOYEES
None of these
INDEX on EMPLOYEES (*)
CREATE on EMPLOYEES
Correct Correct
50. JOE's schema contains a COUNTRIES table. The following commands are executed by JOE and TOM:
(JOE): GRANT SELECT ON countries TO tom WITH GRANT OPTION;
(TOM): GRANT SELECT on joe.countries TO dick WITH GRANT OPTION;
Now, JOE executes:
REVOKE SELECT ON countries FROM tom;
What happens to the grant to DICK?
Mark for Review
(1) Points
Nothing. DICK's privilege is preserved even though TOM lost his privilege.
DICK also loses his SELECT privilege. (*)
The REVOKE statement fails because JOE must remove the SELECT privilege from both users at the same time.
The REVOKE statement fails because only the Database Administrator (not JOE) can revoke privileges.
Correct Correct