Semester 1 Final Exam

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

SEMESTER 1 FINAL EXAM

Section 5
(Answer all questions in this section)

1. Identify the valid collection types: Mark for Review


(1) Points

(Choose all correct answers)

INDEX BY TABLE OF RECORDS (*)

INDEX BY VIEW

INDEX BY TABLE (*)

INDEX BY TABLE OF ROWS

Correct Correct

2. You can use %ROWTYPE with tables and views. Mark for Review
(1) Points

True (*)

False

Correct Correct

Section 6
SEMESTER 1 FINAL EXAM

(Answer all questions in this section)

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

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.

A LOCKED_ROWS exception is raised immediately.

The other user's transaction is automatically rolled back.

Correct Correct

4. A cursor is declared as:


CURSOR c IS SELECT * FROM departments FOR UPDATE;

After opening the cursor and fetching some rows, you want to delete the most recently fetched row.
Which of the following will do this successfully?

Mark for Review


(1) Points

DELETE FROM c WHERE CURRENT OF departments;


SEMESTER 1 FINAL EXAM

DELETE FROM departments WHERE CURRENT OF c; (*)

DELETE FROM c WHERE CURRENT OF c;

None of these.

DELETE FROM departments WHERE c%ROWCOUNT = 1;

Correct Correct

5. The following code fragment shows a cursor FOR loop:


FOR emp_record IN emp_cursor LOOP ......

Which of the following do NOT need to be coded explicitly? (Choose three.)

Mark for Review


(1) Points

(Choose all correct answers)

END LOOP;

FETCH emp_cursor INTO emp_record; (*)

OPEN emp_cursor; (*)

emp_record emp_cursor%ROWTYPE; (*)

DECLARE CURSOR emp_cursor IS ...


SEMESTER 1 FINAL EXAM

Correct Correct

Section 6
(Answer all questions in this section)

6. 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

7. 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 * FROM employees WHERE department_id = 75) LOOP ...

None of these. They are all valid. (*)

FOR emp_rec IN
(SELECT last_name, salary FROM employees) LOOP ...

FOR emp_rec IN
(SELECT last_name, salary FROM employees ORDER BY last_name) LOOP ...
SEMESTER 1 FINAL EXAM

FOR emp_rec IN
(SELECT * FROM employees) LOOP ...

Correct Correct

8. 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 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.
SEMESTER 1 FINAL EXAM

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.

Correct Correct

9. What is wrong with the following code?


DECLARE
CURSOR emp_curs(p_dept_id NUMBER) IS
SELECT * FROM employees WHERE department_id = p_dept_id;
BEGIN
FOR dept_rec IN (SELECT * FROM departments) LOOP
DBMS_OUTPUT.PUT_LINE(dept_rec.department_name);
FOR emp_rec IN emp_curs(dept_rec.department_id) LOOP
DBMS_OUTPUT.PUT_LINE(emp_rec.last_name);
END LOOP;
END LOOP;
END;
Mark for Review
(1) Points

EMP_CURS should not be DECLAREd explicitly; it should be coded as a subquery in a cursor FOR
loop.

Nothing is wrong. The block will execute successfully and display all departments and the
employees in those departments. (*)

You cannot use a cursor with a subquery in nested loops.

The DEPARTMENTS cursor must be declared with a parameter.


SEMESTER 1 FINAL EXAM

You cannot use two different kinds of loops in a single PL/SQL block.

Correct Correct

10. Examine the following code:


DECLARE
CURSOR emp_curs IS
SELECT last_name, salary
FROM employees
ORDER BY salary;
v_last_name employees.last_name%TYPE;
v_salary employees.salary%TYPE;
BEGIN
...
Which of the following statements successfully opens the cursor and fetches the first row of the active
set?

Mark for Review


(1) Points

OPEN emp_curs;
FETCH emp_curs;

OPEN emp_curs;
FETCH emp_curs INTO v_last_name, v_salary;
(*)

OPEN emp_curs;
FETCH emp_curs INTO v_salary, v_last_name;

OPEN emp_curs;
FETCH FIRST emp_curs INTO v_last_name, v_salary;
SEMESTER 1 FINAL EXAM

Correct Correct

Section 6
(Answer all questions in this section)

11. 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?

Mark for Review


(1) Points

No value will be displayed

An INVALID_CURSOR exception will be raised when you try to FETCH the row.

Smith (*)

Smith and Jones (the row will be fetched twice)


SEMESTER 1 FINAL EXAM

Jones

Correct Correct

12. Which of these is NOT a valid cursor declaration? Mark for Review
(1) Points

CURSOR emp_curs IS
SELECT salary
FROM employees
ORDER BY salary DESC;

CURSOR emp_curs IS
SELECT salary
FROM employees
WHERE last_name LIKE 'S%';

CURSOR emp_dept_curs IS
SELECT e.salary, d.department_name
FROM employees e, departments d
WHERE e.department_id = d.department_id;

CURSOR emp_curs IS
SELECT salary INTO v_salary
FROM employees;
(*)

Correct Correct

13. Examine the following code:


SEMESTER 1 FINAL EXAM

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;

There are 10 rows in the DEPARTMENTS table. What will happen when this code is executed?

Mark for Review


(1) Points

The last row will be displayed twice. (*)

10 rows will be displayed, followed by a row of NULL values.

A NO_DATA_FOUND exception will be raised.

10 rows will be displayed.

The loop will execute forever; the same 10 rows will be displayed over and over again.

Correct Correct

14. Look at the following code:


DECLARE
CURSOR emp_curs (p_dept_id employees.department_id%TYPE) IS
SELECT * FROM employees
SEMESTER 1 FINAL EXAM

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 following are correct at
Point A?

Mark for Review


(1) Points

50

v_deptid

100 / 2

All of these. (*)

Correct Correct

15. 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 IN NUMBER)


SEMESTER 1 FINAL EXAM

Nothing is wrong; the cursor declaration is correct.

A parameter is missing. The parameter should be coded as: (p_loc_id NUMBER) (*)

The declaration is invalid. You cannot reference a cursor parameter in a WHERE clause.

Incorrect Incorrect. Refer to Section 6 Lesson 4.

Section 6
(Answer all questions in this section)

16. 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?

Mark for Review


(1) Points

EXIT WHEN country_curs%FOUND(25);

EXIT WHEN country_curs%ROWCOUNT > 25; (*)

WHEN country_curs > 25 THEN EXIT; END IF;

EXIT WHEN ROWCOUNT > 25;


SEMESTER 1 FINAL EXAM

Correct Correct

17. 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

Cursor

Scalar

Record (*)

Row

Correct Correct

18. You can reference explicit cursor attributes directly in a SQL statement. True or
False? Mark for Review
(1) Points

True

False (*)
SEMESTER 1 FINAL EXAM

Correct Correct

Section 7
(Answer all questions in this section)

19. The following EXCEPTION section is constructed correctly. True or False?


EXCEPTION
WHEN NO_DATA_FOUND OR TOO_MANY_ROWS
THEN statement_1;
statement_2;
WHEN OTHERS
THEN statement_3;
END;

Mark for Review


(1) Points

TRUE (*)

FALSE

Correct Correct

20. 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 (*)
SEMESTER 1 FINAL EXAM

Correct Correct

Section 7
(Answer all questions in this section)

21. Examine the following code. Why does this exception handler not follow good
practice guidelines? (Choose two.)
DECLARE
v_dept_name departments.department_name%TYPE;
BEGIN
SELECT department_name INTO v_dept_name FROM departments
WHERE department_id = 75;
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE('A select returned more than one row');
END;
Mark for Review
(1) Points

(Choose all correct answers)

The exception handler should test for the named exception NO_DATA_FOUND. (*)

department_id 75 does not exist in the departments table.

You should not use DBMS_OUTPUT.PUT_LINE in an exception handler.

The exception handler should COMMIT the transaction.

The exception section should include a WHEN TOO_MANY_ROWS exception handler. (*)
SEMESTER 1 FINAL EXAM

Correct Correct

22. A user-defined exception must be declared as a variable of data type


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

TRUE (*)

FALSE

Correct Correct

23. The following line of code is correct. True or False?


RAISE_APPLICATION_ERROR(-21001,'My error message'); Mark for Review
(1) Points

True

False (*)

Correct Correct

24. What will be displayed when the following code is executed?


DECLARE
e_myexcep EXCEPTION;
BEGIN
DBMS_OUTPUT.PUT_LINE('Message 1');
RAISE e_myexcep;
DBMS_OUTPUT.PUT_LINE('Message 2');
EXCEPTION
WHEN e_myexcep THEN
SEMESTER 1 FINAL EXAM

DBMS_OUTPUT.PUT_LINE('Message 3');
RAISE e_myexcep;
DBMS_OUTPUT.PUT_LINE('Message 4');
END;
Mark for Review
(1) Points

The code will execute but will return an unhandled exception to the calling environment.
(*)

Message 1
Message 3
Message 4

Message 1
Message 3

The code will not execute because it contains at least one syntax error.

Message 1
Message 2
Message 3
Message 4

Correct Correct

25. Examine the followiing code. Which exception handlers would successfully trap
the exception which will be raised when this code is executed? (Choose two.)
DECLARE
CURSOR emp_curs IS SELECT * FROM employees;
v_emp_rec emp_curs%ROWTYPE;
BEGIN
FETCH emp_curs INTO v_emp_rec;
SEMESTER 1 FINAL EXAM

OPEN emp_curs;
CLOSE emp_curs;
EXCEPTION ...
END;
Mark for Review
(1) Points

(Choose all correct answers)

WHEN INVALID_FETCH

WHEN CURSOR_NOT_OPEN

WHEN NO_DATA_FOUND

WHEN OTHERS (*)

WHEN INVALID_CURSOR (*)

Correct Correct

Section 7
(Answer all questions in this section)

26. Which kinds of exceptions are raised implicitly (i.e., automatically)? (Choose
two.) Mark for Review
(1) Points

(Choose all correct answers)

Non-predefined Oracle Server errors such as ORA-01400 (*)


SEMESTER 1 FINAL EXAM

All errors

User-defined errors

Predefined Oracle Server errors such as NO_DATA_FOUND (*)

Correct Correct

27. Which of the following best describes a user-defined exception? Mark for
Review
(1) Points

Any error which has an Oracle error number of the form ORA-nnnnn

A non-predefined Oracle Server error such as ORA-01400

An error which is not automatically raised by the Oracle server (*)

A predefined Oracle Server error such as NO_DATA_FOUND

Correct Correct

28. Predefined Oracle Server exceptions such as NO_DATA_FOUND can be raised


automatically in inner blocks and handled in outer blocks. True or False? Mark for Review
(1) Points

True (*)
SEMESTER 1 FINAL EXAM

False

Correct Correct

29. What will be displayed when the following code is executed?


<< outer>>
DECLARE
v_myvar NUMBER;
BEGIN
v_myvar := 25;
DECLARE
v_myvar NUMBER := 100;
BEGIN
outer.v_myvar := 30;
v_myvar := v_myvar / 0;
outer.v_myvar := 35;
END;
v_myvar := 40;
EXCEPTION
WHEN ZERO_DIVIDE THEN
DBMS_OUTPUT.PUT_LINE(v_myvar);
END;
Mark for Review
(1) Points

25

100

30 (*)

40

35
SEMESTER 1 FINAL EXAM

Correct Correct

Section 8
(Answer all questions in this section)

30. Which of the following are benefits of using PL/SQL subprograms rather than
anonymous blocks? (Choose three.) Mark for Review
(1) Points

(Choose all correct answers)

Better data security (*)

Easier code maintenance (*)

Faster performance (*)

Easier to write

Do not need to declare variables

Incorrect Incorrect. Refer to Section 8 Lesson 1.

Section 8
(Answer all questions in this section)
SEMESTER 1 FINAL EXAM

31. A PL/SQL procedure named MY_PROC1 has been successfully created in the
database. The procedure has no parameters. Which of the following will successfully invoke the
procedure in Application Express? (Choose two.) Mark for Review
(1) Points

(Choose all correct answers)

SELECT my_proc1 FROM DUAL;

EXECUTE my_proc1;

CREATE OR REPLACE PROCEDURE my_proc2 IS


BEGIN
my_proc1;
END my_proc2;
(*)

DECLARE
v_var1 NUMBER := 20;
BEGIN
my_proc1(v_var1);
END;

BEGIN
my_proc1;
END;
(*)

Incorrect Incorrect. Refer to Section 8 Lesson 1.

32. Which of the following are characteristics of PL/SQL stored procedures? (Choose
three.) Mark for Review
SEMESTER 1 FINAL EXAM

(1) Points

(Choose all correct answers)

They can accept parameters. (*)

They can be invoked from inside a SQL statement.

They are named PL/SQL blocks. (*)

They must return exactly one value to the calling environment.

They can have an exception section. (*)

Correct Correct

33. Which of the following is NOT correct coding for a procedure parameter?
Mark for Review
(1) Points

(p_param IN NUMBER)

(p_param VARCHAR2(50)) (*)

(p_param IN VARCHAR2)

(p_param employees.last_name%TYPE)

(p_param VARCHAR2)
SEMESTER 1 FINAL EXAM

Correct Correct

34. Which of the following best describes how an input parameter affects a
procedure? Mark for Review
(1) Points

It makes the procedure execute faster.

It describes which parts of the procedure's code are optional or conditional.

It allows complex calculations to be executed inside the procedure.

It describes the order in which the procedure's statements should be executed.

It passes a value into the procedure when the procedure is invoked. (*)

Incorrect Incorrect. Refer to Section 8 Lesson 2.

35. What are the types of parameter modes? Mark for Review
(1) Points

LOCAL, GLOBAL, BOTH

CONSTANT, VARIABLE, DEFAULT

IN, OUT, IN OUT (*)


SEMESTER 1 FINAL EXAM

CHARACTER, NUMBER, DATE, BOOLEAN

Correct Correct

Section 8
(Answer all questions in this section)

36. Which of the following statements about IN OUT parameters are true? (Choose
two.) Mark for Review
(1) Points

(Choose all correct answers)

The parameter value passed into the subprogram is always returned unchanged to the calling
environment.

The parameter value can be returned as a new value that is set within the procedure. (*)

The parameter value can be returned as the original unchanged value. (*)

The data type for the parameter must be VARCHAR2.

Incorrect Incorrect. Refer to Section 8 Lesson 3.

Section 9
(Answer all questions in this section)

37. Your schema contains two procedures named CHILD1 and CHILD2. You now
create a third procedure by executing:
CREATE OR REPLACE PROCEDURE parent IS
SEMESTER 1 FINAL EXAM

BEGIN
child1;
child2;
END;
You now want user JOE to be able to invoke PARENT. Which of the following gives JOE the privileges he
needs, but no unnecessary privileges?

Mark for Review


(1) Points

GRANT EXECUTE ON parent TO joe WITH ADMIN OPTION;

GRANT EXECUTE ON parent, child1, child2 TO joe;

GRANT EXECUTE ON parent TO joe;


GRANT EXECUTE ON child1 TO joe;
GRANT EXECUTE ON child2 TO joe;

GRANT EXECUTE ON * TO joe;

GRANT EXECUTE ON parent TO joe;


(*)

Incorrect Incorrect. Refer to Section 9 Lesson 5.

38. You want to allow user JOE to query the CD_DETAILS table in your schema.
Which command should you use? Mark for Review
(1) Points

GRANT cd_details TO joe;


SEMESTER 1 FINAL EXAM

GRANT QUERY ON cd_details TO joe;

GRANT SELECT TO joe ON cd_details;

GRANT SELECT ON cd_details TO joe; (*)

GRANT SELECT ON joe TO cd_details;

Correct Correct

39. Which of the following is the correct syntax to create a procedure using
Invoker's Rights? Mark for Review
(1) Points

CREATE PROCEDURE myproc IS


BEGIN
AUTHID CURRENT_USER ...

CREATE PROCEDURE myproc


AUTHID CURRENT_USER IS
BEGIN ...
(*)

CREATE PROCEDURE AUTHID CURRENT_USER myproc IS


BEGIN ...

CREATE PROCEDURE myproc IS


AUTHID CURRENT_USER
BEGIN ...
SEMESTER 1 FINAL EXAM

Correct Correct

40. User REYHAN creates the following procedure:


CREATE PROCEDURE proc1
AUTHID CURRENT_USER IS
v_count NUMBER;
BEGIN
SELECT COUNT(*) INTO v_count
FROM tom.employees;
END;

User BILL wants to execute this procedure. What privileges will BILL need?

Mark for Review


(1) Points

EXECUTE on REYHAN.PROC1

None of these. The procedure will fail to compile because REYHAN does not have SELECT
privilege on TOM.EMPLOYEES.

SELECT on TOM.EMPLOYEES

EXECUTE on REYHAN.PROC1 and SELECT on TOM.EMPLOYEES (*)

BILL needs no privileges

Correct Correct

Section 9
(Answer all questions in this section)
SEMESTER 1 FINAL EXAM

41. Which of the following best describes the Data Dictionary? Mark for
Review
(1) Points

It is a set of tables which can be updated by any user who has the necessary privileges.

It contains a list of all database tables which are not in any schema.

It contains a backup copy of all the data in the database.

It is an automatically managed master catalog of all the objects stored in the database. (*)

Incorrect Incorrect. Refer to Section 9 Lesson 3.

42. User BOB is not a database administrator. BOB wants to see the names of all the
tables in his schema, as well as all the tables in other users' schemas which he has privileges to use.
Which Data Dictionary view would BOB query to do this? Mark for Review
(1) Points

None of these.

USER_TAB_COLUMNS

DBA_TABLES

ALL_TABLES (*)

USER_TABLES
SEMESTER 1 FINAL EXAM

Correct Correct

43. Why will the following statement fail?


SELECT employee_id, tax(p_value => salary)
FROM employees;

Mark for Review


(1) Points

User-defined functions are not allowed in the SELECT clause.

The data type for the tax variable does not match the data type for salary.

The statement will execute and not fail.

Name notation is not allowed. (*)

Incorrect Incorrect. Refer to Section 9 Lesson 2.

44. Function DOUBLE_SAL has been created as follows: CREATE OR REPLACE


FUNCTION double_sal (p_salary IN employees.salary%TYPE) RETURN NUMBER IS BEGIN
RETURN(p_salary * 2); END; Which of the following calls to DOUBLE_SAL will NOT work? Mark for
Review

(1) Points

SELECT * FROM employees WHERE double_sal(salary) > 20000;

None, they will all work (*)


SEMESTER 1 FINAL EXAM

SELECT * FROM employees ORDER BY double_sal(salary) DESC;

UPDATE employees SET salary = double_sal(salary);

SELECT last_name, double_sal(salary) FROM employees;

Correct Correct

45. When creating a user-defined function that will be called from a SQL statement,
the size of the returned values may be up to the size of any PL/SQL data type. True or False? Mark
for Review
(1) Points

True

False (*)

Incorrect Incorrect. Refer to Section 9 Lesson 2.

Section 9
(Answer all questions in this section)

46. Examine the following code:


CREATE OR REPLACE FUNCTION add_func
(p_param1 NUMBER, p_param2 NUMBER)
RETURN NUMBER
IS
BEGIN
RETURN (p_param1 + p_param2);
END;
What will be displayed when the following SQL statement is executed?
SELECT add_func(6, add_func(3,8)) FROM dual;
SEMESTER 1 FINAL EXAM

Mark for Review


(1) Points

17 (*)

11

66

23

An error message will be displayed because you cannot nest user-defined functions.

Correct Correct

47. Which of the following is a difference between a procedure and a function?


Mark for Review
(1) Points

A procedure can return a BOOLEAN datatype, while a function cannot.

A function must have at least one IN parameter, while parameters are optional for a procedure.

A function can be used inside a SQL statement, while a procedure cannot. (*)

A procedure can include DML statements, but a function cannot.

A procedure can include an EXCEPTION section, while a function cannot.


SEMESTER 1 FINAL EXAM

Incorrect Incorrect. Refer to Section 9 Lesson 1.

48. Consider the following function:


CREATE FUNCTION ADD_EM
(a NUMBER := 1,
b NUMBER := 2 )
RETURN NUMBER
IS BEGIN
RETURN (a+b);
END ADD_EM;

Which one of the following blocks will NOT work correctly?

Mark for Review


(1) Points

DECLARE
x NUMBER;
BEGIN
x:= add_em(b=4);
END;
(*)

DECLARE
x NUMBER;
BEGIN
x:= add_em(4);
END;

DECLARE
x NUMBER;
BEGIN
x:= add_em(4,5);
END;
SEMESTER 1 FINAL EXAM

DECLARE
x NUMBER;
BEGIN
x:= add_em;
END;

None of them will work.

Correct Correct

49. 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.

The database automatically drops PARENT as well.

CHILD2 is dropped successfully. PARENT is marked INVALID, but CHILD1 is still valid. (*)

The database automatically drops CHILD1 as well.


SEMESTER 1 FINAL EXAM

CHILD2 is dropped successfully. PARENT and CHILD1 are both marked INVALID.

Correct Correct

50. Which Data Dictionary view can be used to display the detailed code of a
procedure in your schema? Mark for Review
(1) Points

USER_SOURCE (*)

USER_OBJECTS

USER_PROCEDURES

USER_SUBPROGRAMS

None of these

Incorrect Incorrect. Refer to Section 9 Lesson 4.

You might also like