Test: Semester 1 Final Exam 1.
Which of the following tools can NOT be used to develop and test PL/SQL code? Mark for Review (1) Points Oracle Jdeveloper Oracle Application Express Oracle JSQL (*) Oracle iSQL*Plus Section 1 1. In which part of the PL/SQL block are declarations of variables defined? Mark for Review (1) Points Executable Exception Declarative (*) Definition 2. A program which specifies a list of operations to be performed sequentially t o achieve the desired result can be called: Mark for Review (1) Points declarative nondeclarative procedural (*) low level 3. What is the data type of the variable V_DEPT_TABLE in the following declarati on? DECLARE TYPE dept_table_type IS TABLE OF departments%ROWTYPE INDEX BY PLS_INTEGER; v_dep t_table dept_table_type; ... Scalar Composite (*) LOB 4. Which of the following can be assigned to a Boolean variable? 1. Null 2. False 3. True 4. 0 Mark for Review (1) Points
2 and 3 2, 3 and 4 1, 2 and 3 (*) 1, 2, 3 and 4 5. Which of the following are PL/SQL lexical units? (Choose two.) Mark Identifie rs (*) Table Columns Reserved Words (*) Anonymous Blocks SQL Workshop 6. What is wrong with this assignment statement? myvar := 'To be or not to be'; 'That is the question'; An assignment statement must be a single line of code Nothing is wrong, the statement is fine An assignment statement must have a single semicolon at the end (*) "myvar" is not a valid name for a variable Character literals should not be enclosed in quotes Incorrect. Refer to Section 2 Lesson 5. 7. When an exception occurs within a PL/SQL block, the remaining statements in t he executable section of the block are skipped. True or False? Mark for Review (1) Points True (*) False Correct
Section 3 8. The MERGE statement will INSERT or DELETE rows in a target table based on mat ching values in a source table. True or False? Mark for Review (1) Points True
False (*) Incorrect. Refer to Section 3 Lesson 1. 9. Which rows will be deleted from the EMPLOYEES table when the following code i s executed? DECLARE salary employees.salary%TYPE := 12000; BEGIN DELETE FROM employees WHERE salary > salary; END; All rows whose SALARY column value is greater than 12000. All rows in the table. No rows. (*) All rows whose SALARY column value is equal to 12000. 10. You declare an implicit cursor in the DECLARE section of a PL/SQL block. Tru e or False? Mark for Review (1) Points True False (*)
11. Which statement best describes when a WHILE loop shouild be used? Mark When the number of iterations is known When repeating a sequence of statements until the controlling condition is no lo nger true (*) When assigning a value to a Boolean variable When testing whether a variable is null Incorrect. Refer to Section 4 Lesson 4. 12. What kinds of loops can be nested? Mark for Review (1) Points BASIC loops WHILE loops FOR loops All of the above (*)
13. What will be the value of v_result after the following code is executed? DECLARE v_grade CHAR(1) := NULL; v_result VARCHAR2(10); BEGIN CASE v_grade WHEN ('A' OR 'B') THEN v_result := 'Very Good'; WHEN ('E' OR 'F') THEN v_result := 'Poor'; ELSE v_result := 'In Between'; END CASE; END; Poor In Between (*) Null Very Good 14. The EXIT statement can be located anywhere inside a basic loop. True or True (*) False 15. What is the correct name for CASE, LOOP, WHILE, and IF-THEN-ELSE structures ? Mark for Review (1) Points Control structures (*) Array structures Memory structures Cursor structures 16. Examine the following code fragment: DECLARE CURSOR emp_curs IS SELECT first_name, last_name FROM employees; v_emp_rec emp_curs%ROWTYPE; BEGIN ... FETCH emp_curs INTO v_emp_rec; DBMS_OUTPUT.PUT_LINE(.. Point A ...); ... To display the fetched last name, what should you code at Point A? v_emp_rec.last_name (*) v_emp_rec(last_name) v_emp_rec last_name None of the above 17. You want to display all locations, and the departments in each location. Exa mine the following code:
DECLARE CURSOR loc_curs IS SELECT * FROM locations; CURSOR dept_curs(p_loc_id NUMBER) IS SELECT * FROM departments WHERE location_id = p_loc_id; BEGIN FOR loc_rec IN loc_curs LOOP DBMS_OUTPUT.PUT_LINE(loc_rec.city); FOR dept_rec IN dept_curs(-- Point A --) LOOP DBMS_OUTPUT.PUT_LINE(dept_rec.department_name); END LOOP; END LOOP; END; What should you code at Point A? p_loc_id location_id null LOOP ... END LOOP; loc_rec.location_id (*) Correct 18. What is one of the advantages of using parameters with a cursor? Mark You ca n use a cursor FOR loop. You can declare the cursor FOR UPDATE. You do not need to DECLARE the cursor at all. You can use a single cursor to fetch a different set of rows each time the curso r is opened. (*) It will execute much faster than a cursor without parameters. 19. Examine the following code: DECLARE CURSOR c IS SELECT * FROM employees FOR UPDATE; c_rec c%ROWTYPE; BEGIN OPEN c; FOR i IN 1..20 LOOP FETCH c INTO c_rec; IF i = 6 THEN UPDATE employees SET first_name = 'Joe' WHERE CURRENT OF c; END IF; END LOOP; CLOSE c; END; Which employee row or rows will be updated when this block is executed? Mark for Review (1) Points
The first 6 fetched rows will be updated. No rows will be updated because you locked the rows when the cursor was opened. The 6th fetched row will be updated. (*) The block will not compile because the cursor should have been declared .... FOR UPDATE WAIT 5; None of the above. Incorrect. Refer to Section 5 Lesson 5. 20. What is wrong with the following code? BEGIN FOR emp_rec IN (SELECT * FROM employees WHERE ROWNUM < 10 FOR UPDATE NOWAIT) LOOP DBMS_OUTPUT.PUT_LINE(emp_rec%ROWCOUNT || emp_rec.last_name): END LOOP; END; Mark for Review (1) Points You cannot use FOR UPDATE NOWAIT with a cursor FOR loop using a subquery. You cannot reference %ROWCOUNT with a cursor FOR loop using a subquery. (*) The field EMP_REC.LAST_NAME does not exist. You cannot use ROWNUM with a cursor FOR loop. The cursor has not been opened. Incorrect. Refer to Section 5 Lesson 3.
Page 2 of 5
Test: PL/SQL Institute Exit Exam
Review your answers, feedback, and question scores below. An asterisk (*) indica tes a correct answer. Section 5 21. For which type of SQL statement must you use an explicit cursor? Mark for Re view
(1) Points DML statements that process more than one row. Queries that return more than one row. (*) Data Definition Language (DDL) statements. Queries that return a single row. Incorrect. Refer to Section 5 Lesson 1.
Section 6 22. Which of the following can NOT be coded in the body of a DML trigger? (Choos e two.) Mark for Review (1) Points (Choose all correct answers) IF DELETING THEN IF SELECTING THEN (*) IF INSERTING THEN IF UPDATING ('JOB_ID') THEN IF OTHERS THEN (*) Incorrect. Refer to Section 6 Lesson 1. 23. Examine this code: CREATE TRIGGER new_trigg AFTER CREATE ON reserved_word BEGIN ... Which of the following can be used in place of reserved_word? (Choose two.) Mark for Review (1) Points (Choose all correct answers) TABLE SCHEMA (*) USER DATABASE (*) TABLE employees
Incorrect. Refer to Section 6 Lesson 2.
Section 7 24. How can you retrieve the error code and error message of any Oracle Server e xception? Mark for Review (1) Points By using the functions SQLCODE and SQLERRM (*) By using the functions SQLCODE and SQLERR By using RAISE_APPLICATION_ERROR By defining an EXCEPTION variable and using PRAGMA EXCEPTION_INIT Incorrect. Refer to Section 7 Lesson 2. 25. A user-defined exception can be raised: A. In the declaration section B. In the executable section C. In the exception section Mark for Review (1) Points B C A and B B and C (*) A and C Incorrect. Refer to Section 7 Lesson 3. 26. 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 have a subblock inside an exception s ection.
It will fail to compile because e_excep1 is out of scope in the subblock. It will fail to compile because you cannot declare more than one exception in th e same block. It will compile successfully and return an unhandled e_excep2 to the calling env ironment. (*) Incorrect. Refer to Section 7 Lesson 4. 27. 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 (*) Incorrect. Refer to Section 7 Lesson 1.
Section 8 28. 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) Easier to write Better data security (*) Easier code maintenance (*) Faster performance (*) Do not need to declare variables Incorrect. Refer to Section 8 Lesson 1. 29. What are the type of parameter modes? Mark for Review (1) Points CHARACTER, NUMBER, DATE, BOOLEAN CONSTANT, VARIABLE, DEFAULT LOCAL, GLOBAL, BOTH IN, OUT, IN OUT (*)
Incorrect. Refer to Section 8 Lesson 3. 30. You have created a procedure named MYPROC that accepts three IN parameters A , B, and C (all numbers). Which of the following calls to MYPROC is NOT correct? Mark for Review (1) Points myproc(5,10,20); myproc(a=>5,b=>10,20) (*) myproc(a=>5,b=>10,c=>20) myproc(5,10,c=>20) Incorrect. Refer to Section 8 Lesson 2.
Page 3 of 5
Test: PL/SQL Institute Exit Exam
Review your answers, feedback, and question scores below. An asterisk (*) indica tes a correct answer. Section 9 31. Which of the following best describes a stored function? Mark for Review (1) Points A subprogram that must return exactly one value. (*) A subprogram that must have at least one IN parameter. A subprogram that has no OUT or IN OUT parameters. A subprogram that executes automatically when a DML statement is executed on a t able. A subprogram which invokes another subprogram. Correct 32. What will happen when the following procedure is executed? PROCEDURE log_usage (p_card_id NUMBER, p_loc NUMBER) IS PRAGMA AUTONOMOUS_TRANSACTION
BEGIN INSERT INTO log_table (card_id, location, tran_date) VALUES (p_card_id, p_loc, SYSDATE); COMMIT; END log_usage; Mark for Review (1) Points The subprogram will fail because the PRAGMA statement must be before IS. The subprogram will fail because it is missing AUTHID CURRENT_USER before IS. The compilation will fail because a semicolon after AUTONOMOUS_TRANSACTION is re quired. (*) The program will compile successfully. Incorrect. Refer to Section 9 Lesson 6. 33. When creating a user-defined function, the size of the returned values may b e up to the size of any PL/SQL data type. True or False? Mark for Review (1) Points True False (*) Incorrect. Refer to Section 9 Lesson 2. 34. You want to remove the procedure NO_NEED from your schema. You execute: DROP PROCEDURE no_need; Which Data Dictionary views are updated automatically? Mark for Review (1) Points USER_PROCEDURES USER_OBJECTS USER_SOURCE All of the above. (*) None of the above. Incorrect. Refer to Section 9 Lesson 4.
Section 10 35. Which of the following are good reasons for creating and using Packages?
Related procedures, functions and variables can be grouped together as a single unit We can recompile the package body without having to recompile the specification We can create packages without needing any system privileges We can declare INDEX BY tables and use them as parameters Mark for Review (1) Points A and B A, B and C A and C A, B and D (*) A, B, C and D Incorrect. Refer to Section 10 Lesson 1. 36. We want to remove the specification (but not the body) of package BIGPACK fr om the database. Which of the following commands will do this? Mark for Review (1) Points DROP PACKAGE bigpack; DROP PACKAGE SPECIFICATION bigpack; DROP PACKAGE bigpack SPECIFICATION; DROP PACKAGE HEADER bigpack; None of the above (*) Correct 37. What is the correct format to declare a variable using the following emp_pkg package composite data type? TYPE emprec_type IS TABLE OF employees%ROWTYPE IND EX BY BINARY_INTEGER; Mark for Review (1) Points emp_pkg.emprec_type; emprec_type.emp_pkg; v_emp_table emprec_type.emp_pkg; v_emp_table emp_pkg.emprec_type; (*) None of the above Incorrect. Refer to Section 10 Lesson 3.
Section 11 38. Package CURSPACK declares a global cursor in the package specification. The package contains three public procedures: OPENPROC opens the cursor; FETCHPROC f etches 5 rows from the cursor's active set; CLOSEPROC closes the cursor. What will happen when a user session executes the following commands in the orde r shown? curspack.openproc; -- line 1 curspack.fetchproc; -- line 2 curspack.fetchproc; -- line 3 curspack.openproc; -- line 4 curspack.fetchproc; -- line 5 curspack.closeproc; -- line 6 Mark for Review (1) Points The first 15 rows will be fetched. The first 10 rows will be fetched, then the first 5 rows will be fetched again. The first 5 rows will be fetched three times. An error will occur at line 2. An error will occur at line 4. (*) Incorrect. Refer to Section 11 Lesson 1. 39. DBMS_OUTPUT.PUT_LINE can be invoked from inside a private packaged function. True or False? Mark for Review (1) Points True (*) False Incorrect. Refer to Section 11 Lesson 2.
Section 13 40. You can use a trigger to prevent rows from being deleted from the EMPLOYEES table on Mondays. True or False? Mark for Review (1) Points True (*) False Incorrect. Refer to Section 13 Lesson 1.
Page 4 of 5
Test: PL/SQL Institute Exit Exam
Review your answers, feedback, and question scores below. An asterisk (*) indica tes a correct answer. Section 13 41. What is wrong with the following code? CREATE TRIGGER dept_trigg BEFORE UPDATE OF department_name ON departments BEGIN DBMS_OUTPUT.PUT_LINE(:NEW.department_name); END; Mark for Review (1) Points You cannot use :NEW in a BEFORE trigger, only in an AFTER trigger. You cannot use :NEW or :OLD in a statement trigger. (*) You cannot use DBMS_OUTPUT.PUT_LINE inside a trigger. The second line should be: BEFORE UPDATE ON departments.department_name
Correct 42. MARY and JOE's schemas each contain an EMPLOYEES table. JOE creates the foll owing trigger: CREATE TRIGGER upd_trigg AFTER DELETE ON joe.employees FOR EACH ROW BEGIN DELETE FROM mary.employees WHERE employee_id = :OLD.employee_id; END; A third user TOM needs to delete rows from JOE's EMPLOYEES table. What object pr ivileges will TOM and JOE need? Mark for Review (1) Points TOM does not need any object privileges, but JOE needs DELETE on both TOM.EMPLOY EES and MARY.EMPLOYEES TOM needs DELETE on JOE.EMPLOYEES and JOE needs DELETE on MARY.EMPLOYEES (*)
JOE does not need any object privileges, but TOM needs DELETE on MARY.EMPLOYEES TOM needs DELETE on MARY.EMPLOYEES and JOE needs EXECUTE on TOM.UPD_TRIGG Incorrect. Refer to Section 13 Lesson 5. 43. In the following code: CREATE TRIGGER mytrigg INSTEAD OF INSERT OR UPDATE ON my_object_name FOR EACH ROW BEGIN ... my_object_name can be the name of a table. True or False? Mark for Review (1) Points True False (*) Correct 44. Examine the following code: CREATE TRIGGER emp_trigg AFTER UPDATE OF salary ON employees FOR EACH ROW DECLARE v_count NUMBER; BEGIN -- Line A END; Which of the following statements is NOT allowed at Line A? Mark for Review (1) Points SELECT count(*) INTO v_count FROM departments; UPDATE employees SET job_id = 'IT_PROG' WHERE employee_id = :OLD.employee_id; SELECT count(*) INTO v_count FROM employees; (*) DBMS_OUTPUT.PUT_LINE('A salary was updated'); None. All of the above are allowed. Incorrect. Refer to Section 13 Lesson 4.
Section 14 45. When a table is dropped, all PL/SQL subprograms that reference the table are automatically dropped. True or False? Mark for Review
(1) Points True False (*) Incorrect. Refer to Section 14 Lesson 1. 46. If two related objects are in different databases, the dependency between th em is automatically recorded on the dependent object's data dictionary. True or False? Mark for Review (1) Points True False (*) Correct
Section 15 47. Obfuscation does not allow anyone to see the source code, including the owne r. True or False? Mark for Review (1) Points True (*) False Incorrect. Refer to Section 15 Lesson 4. 48. Conditional compilation allows you to determine what code will be compiled b ased on select criteria you specify using inquiry directives. True or False? Mar k for Review (1) Points True False (*) Incorrect. Refer to Section 15 Lesson 3. 49. To determine the current setting for PLSQL_OPTIMIZE_LEVEL, query the data di ctionary view USER_PLSQL_OBJECTS_SETTING. True or False? Mark for Review (1) Points True False (*)
Incorrect. Refer to Section 15 Lesson 1. 50. In the USER_ERRORS data dictionary view, if an error is prefixed with "Warni ng," the command completes but has a side effect the user needs to know about. F or all other errors, the command terminates abnormally. True or False? Mark for Review (1) Points True (*) False
2. PL/SQL extends SQL by including all of the following except: Mark for Review (1) Points variables conditional statements reusable program units constants nonprocedural constructs (*) Incorrect. Refer to Section 1. 3. The fact that PL/SQL is portable is a good thing because: Mark for Review (1) Points Exceptions can be ported to different operating systems Blocks can be sent to the operating system. PL/SQL code can be developed on one platform and deployed on another (*) PL/SQL code can be run on any operating system without a database Incorrect. Refer to Section 1.
Section 2 4. Reserved words can be used as identifiers. True or False? Mark for Review (1) Points True False (*)
Incorrect. Refer to Section 2. 5. Identify which of the following assignment statements are valid. (Choose thre e.) Mark for Review (1) Points (Choose all correct answers) v_last_name := Chandra; v_blackout_date := '31-DEC-2006'; (*) v_population := 333444; (*) v_music_type := 'ROCK'; (*) Incorrect. Refer to Section 2. 6. ______ are meant to store large amounts of data. Mark for Review (1) Points Variables Scalar data types LOBs (*) Incorrect. Refer to Section 2. 7. An exception occurs within the inner block of two nested blocks. The inner bl ock does not have an EXCEPTION section. What always happens? Mark for Review (1) Points Both blocks fail and an error message is displayed by the calling environment The exception is propagated to the outer block (*) Oracle automatically tries to re-execute the inner block The user's database session is automatically disconnected Incorrect. Refer to Section 2. 8. The implicit data type conversion at Point A may not work correctly. Why not? DECLARE v_mydate DATE; BEGIN V_MYDATE := '29-Feb-04'; -- Point A END; Mark for Review (1) Points
There are only 28 days in February Oracle cannot implicitly convert a character string to a date, even if the strin g contains a valid date value If the database language is not English, 'Feb' has no meaning. (*) V_MYDATE has been entered in uppercase Incorrect. Refer to Section 2. 9. A variable must have a value if NOT NULL is specified. True or False? Mark fo r Review (1) Points True (*) False Incorrect. Refer to Section 2.
Section 3 10. You declare an implicit cursor in the DECLARE section of a PL/SQL block. Tru e or False? Mark for Review (1) Points True False (*) Incorrect. Refer to Section 3.
Page 1 of 5
Test: PLSQL Institute Exit Exam
Review your answers, feedback, and question scores below. An asterisk (*) indica tes a correct answer. Section 3 11. A variable is declared as: DECLARE
v_holdit employees.last_name%TYPE; BEGIN ... Which of the following is a correct use of the INTO clause? Mark for Review (1) Points SELECT * INTO v_holdit FROM employees; SELECT last_name INTO v_holdit FROM employees; SELECT last_name INTO v_holdit FROM employees WHERE employee_id=100; (*) SELECT salary INTO v_holdit FROM employees WHERE employee_id=100;
Incorrect. Refer to Section 3. 12. The following anonymous block of code is run: BEGIN INSERT INTO countries (id, name) VALUES ('XA', 'Xanadu'); SAVEPOINT XA; INSERT INTO countries (id, name) VALUES ('NV','Neverland'); COMMIT; ROLLBACK TO XA; END; What happens when the block of code finishes? Mark for Review (1) Points No data is inserted and no errors occur. No data is inserted and an error occurs Two rows are inserted and no errors occur. Two rows are inserted and an error occurs. (*) Incorrect. Refer to Section 3.
Section 4 13. Examine the following code: DECLARE a VARCHAR2(6) := NULL; b VARCHAR2(6) := NULL; BEGIN IF a = b THEN DBMS_OUTPUT.PUT_LINE('EQUAL'); ELSIF a != b THEN DBMS_OUTPUT.PUT_LINE('UNEQUAL'); ELSE DBMS_OUTPUT.PUT_LINE('OTHER'); END IF; END; Which word will be displayed? Mark for Review (1) Points UNEQUAL EQUAL Nothing will be displayed OTHER (*) Incorrect. Refer to Section 4. 14. The EXIT statement can be located anywhere inside a basic loop. True or Fals e? Mark for Review (1) Points True (*) False Incorrect. Refer to Section 4. 15. What will happen when the following code is executed? BEGIN FOR i in 1 ..3 LOOP DBMS_OUTPUT.PUT_LINE (i); i := i + 1; END LOOP; END; Mark for Review (1) Points It will display 1, 2, 3.
It will display 2, 3, 4. It will result in an error because you cannot modify the counter in a FOR loop. (*) It will result in an error because the counter was not explicitly declared. Incorrect. Refer to Section 4. 16. When coding two nested loops, both loops must be of the same type. For examp le, you cannot code a FOR loop inside a WHILE loop. True or False? Mark for Revi ew (1) Points True False (*) Incorrect. Refer to Section 4. 17. What will be the value of v_result after the following code is executed? DECLARE v_grade CHAR(1) := NULL; v_result VARCHAR2(10); BEGIN CASE v_grade WHEN 'A' THEN v_result := 'Very Good'; WHEN 'F' THEN v_result := 'Poor'; ELSE v_result := 'In Between'; END; END; Mark for Review (1) Points Poor In Between (*) Null Very Good Incorrect. Refer to Section 4.
Section 5 18. The employees table contains 20 rows. What will happen when the following co de is executed? DECLARE CURSOR emp_curs IS SELECT job_id FROM employees;
v_job_id employees.job_id%TYPE; BEGIN OPEN emp_curs; LOOP FETCH emp_curs INTO v_job_id; DBMS_OUTPUT.PUT_LINE(v_job_id); EXIT WHEN emp_curs%NOTFOUND; END LOOP; CLOSE emp_curs; END; Mark for Review (1) Points 20 job_ids will be displayed. The block will fail and an error message will be displayed. 21 rows of output will be displayed; the first job_id will be displayed twice. 21 rows of output will be displayed; the last job_id will be displayed twice. (* ) Incorrect. Refer to Section 5. 19. Examine the following code. To display the salary of an employee, what must be coded at Point A? DECLARE CURSOR emp_curs IS SELECT * FROM employees; BEGIN FOR emp_rec IN emp_curs LOOP DBMS_OUTPUT.PUT_LINE( -- what goes here ? ); END LOOP; END; Mark for Review (1) Points salary emp_curs.salary emp_rec.salary (*) employees.salary emp_rec.salary IN emp_curs Incorrect. Refer to Section 5 20. You want to display each row from the DEPARTMENTS table, and immediately und erneath it, a list of all EMPLOYEES in that department. Which of the following i s a good way to do this? Mark for Review (1) Points Use a single cursor, declared as SELECT * FROM employees GROUP BY department_id;
Use two cursors, one for each of the two tables. Declare the EMPLOYEES cursor wi th a parameter for the DEPARTMENT_ID. (*) Write a SELECT statement which JOINs the two tables, and use CONNECT BY PRIOR an d LEVEL to display the rows in the correct order. Use a single cursor with a cursor FOR loop. Change the physical model so that all employee and department data is in a singl e table. Incorrect. Refer to Section 5.
Page 2 of 5
Test: PLSQL Institute Exit Exam
Review your answers, feedback, and question scores below. An asterisk (*) indica tes a correct answer. Section 5 21. Examine the following code fragment: DECLARE CURSOR emp_curs IS SELECT first_name, last_name FROM employees; v_emp_rec emp_curs%ROWTYPE; BEGIN ... FETCH emp_curs INTO v_emp_rec; DBMS_OUTPUT.PUT_LINE(... Point A ...); ... To display the fetched last name, what should you code at Point A? Mark for Review (1) Points v_emp_rec.last_name (*) v_emp_rec(last_name) v_emp_rec last_name None of the above
Incorrect. Refer to Section 5. 22. A cursor has been declared as: CURSOR c_curs (p_param VARCHAR2) IS SELECT * FROM mytable WHERE mycolumn = p_param. Which of the following will open the cursor successfully? Mark for Review (1) Points OPEN c_curs(p_param = 'ABC'); OPEN c_curs('ABC'); (*) OPEN c_curs USING ('ABC'); p_param := 'ABC'; OPEN c_curs(p_param); Incorrect. Refer to Section 5. 23. You want to declare a cursor which locks each row fetched by the cursor. Exa mine the following code: DECLARE CURSOR emp_curs IS SELECT * FROM employees FOR -- Point A Which of the following can NOT be coded at Point A? Mark for Review (1) Points UPDATE; UPDATE OF salary; UPDATE OF employees; (*) UPDATE NOWAIT; Incorrect. Refer to Section 5.
Section 6 24. Which of the following will successfully return a user-defined error message ? Mark for Review (1) Points RAISE_APPLICATION_ERROR('Error Raised',-22001); RAISE_APPLICATION_ERROR(-20257,'Error raised'); (*) RAISE_APPLICATION_ERROR(-22001,'Error Raised'); RAISE_APPLICATION_ERROR('Error Raised',-20257);
Incorrect. Refer to Section 6. 25. Examine the following code. Why does the exception handler not follow good p ractice guidelines? DECLARE v_salary employees.salary%TYPE; BEGIN SELECT salary INTO v_salary FROM employees WHERE employee_id = 999; EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE('An error occurred'); END; Mark for Review (1) Points You should not use DBMS_OUTPUT.PUT_LINE in an exception handler. employee_id 999 does not exist in the employees table. The exception handler should test for the named exception NO_DATA_FOUND. (*) The exception handler should COMMIT the transaction. Incorrect. Refer to Section 6. 26. Which kinds of exceptions are raised implicitly (i.e., automatically)? (Choo se two.) Mark for Review (1) Points (Choose all correct answers) Predefined Oracle Server errors such as NO_DATA_FOUND (*) User-defined errors All errors Non-predefined Oracle Server errors such as ORA-01400 (*) Incorrect. Refer to Section 6. 27. What will be displayed when the following code is executed? <<outer>> DECLARE v_myvar NUMBER; BEGIN v_myvar := 10; DECLARE v_myvar NUMBER := 200; BEGIN outer.v_myvar := 20; v_myvar := v_myvar / 0; -- this raises a ZERO_DIVIDE error
outer.v_myvar := 30; END; v_myvar := 40; EXCEPTION WHEN ZERO_DIVIDE THEN DBMS_OUTPUT.PUT_LINE(v_myvar); END; Mark for Review (1) Points 10 20 (*) 30 40 200 Incorrect. Refer to Section 6.
Section 7 28. A programmer creates a PL/SQL subprogram which is compiled and stored in the database. Two separate users then execute an application which invokes this sub program four times. How many times must the subprogram be recompiled? Mark for R eview (1) Points Twice Four times None (*) Eight times Once Incorrect. Refer to Section 7. 29. Procedure SOMEPROC has five parameters named A, B, C, D, E in that order. Th e procedure was called as follows: SOMEPROC(10,20,D=>50); How was parameter D referenced? Mark for Review (1) Points Positionally Named (*)
A combination of positionally and named A combination of named and defaulted Defaulted Incorrect. Refer to Section 7. 30. You have created a procedure named MYPROC that accepts three IN parameters A , B, and C (all numbers). Which of the following calls to MYPROC is NOT correct? Mark for Review (1) Points myproc(5,10,20); myproc(a=>5,b=>10,20) (*) myproc(a=>5,b=>10,c=>20) myproc(5,10,c=>20) Incorrect. Refer to Section 7.
Page 3 of 5
Test: PLSQL Institute Exit Exam
Review your answers, feedback, and question scores below. An asterisk (*) indica tes a correct answer. Section 8 31. How do you specify that you want a procedure MYPROCA to use "Definer's Right s"? Mark for Review (1) Points CREATE OR REPLACE PROCEDURE myproca AUTHID CURRENT_USER IS... CREATE OR REPLACE PROCEDURE myproca AUTHID OWNER IS... GRANT DEFINER TO myprocA; ALTER PROCEDURE myproca TO DEFINER;
Definer's Rights are the default, therefore no extra code or commands are needed . (*) Incorrect. Refer to Section 8. 32. Which one of the following statements about user-defined functions is NOT tr ue? Mark for Review (1) Points They can execute spell-checking routines. They can be used inside SQL statements. They can be combined (nested) together, similar to nesting system functions, for example INITCAP(SUBSTR( .....)). They can return a TIMESTAMP datatype. They can allow you to COMMIT from inside a SELECT statement. (*) Incorrect. Refer to Section 8. 33. You want to remove the procedure NO_NEED from your schema. You execute: DROP PROCEDURE no_need; Which Data Dictionary views are updated automatically? Mark for Review (1) Points USER_PROCEDURES USER_OBJECTS USER_SOURCE All of the above. (*) None of the above. Incorrect. Refer to Section 8. 34. You have created a function named NEWFUNC. You now change some of the functi on code, and try to recreate the function by executing: CREATE OR REPLACE FUNCTION newfunc .... ; What happens? Mark for Review (1) Points The command fails because the function already exists. The function is automatically dropped and then recreated. (*) The command fails because you should execute: CREATE AND REPLACE ....;
A second function named NEWFUNC_2 is created. The function is dropped but not recreated. Incorrect. Refer to Section 8.
Section 9 35. A public packaged procedure contains the following SQL statement: UPDATE employees SET salary = salary * 1.1; When is this SQL statement parsed? Mark for Review (1) Points When the package specification is created When the package body is created (*) When the package header is loaded into memory. When the package is loaded into memory. Only the first time the procedure is executed. Incorrect. Refer to Section 9. 36. Which two of these declarations cannot be in the same package specification? PROCEDURE myproc PROCEDURE myproc PROCEDURE myproc PROCEDURE myproc Mark for Review (1) Points 1 and 2 1 and 3 (*) 2 and 3 3 and 4 1 and 4 Incorrect. Refer to Section 9. 37. When a user session changes the value of a package variable, the new value c an immediately be seen by other sessions. True or False? Mark for Review (1) Points True (p1 (p1 (p1 (p1 NUMBER, p2 VARCHAR2); VARCHAR2, p2 NUMBER); NUMBER, p2 CHAR); NUMBER);
False (*) Incorrect. Refer to Section 9. 38. Every subprogram which has been declared in a package specification must als o be included in the package body. Triue or False? Mark for Review (1) Points True (*) False Incorrect. Refer to Section 9. 39. We want to remove the specification (but not the body) of package BIGPACK fr om the database. Which of the following commands will do this? Mark for Review (1) Points DROP PACKAGE bigpack; DROP PACKAGE SPECIFICATION bigpack; DROP PACKAGE bigpack SPECIFICATION; DROP PACKAGE HEADER bigpack; None of the above (*) Incorrect. Refer to Section 9. 40. What will be displayed when the following code is executed? BEGIN DBMS_OUTPUT.PUT('I do like'); DBMS_OUTPUT.PUT_LINE('to be'); DBMS_OUTPUT.PUT('beside the seaside'); END; Mark for Review (1) Points I do like to be beside the seaside I do like to be beside the seaside I do like to be I do liketo be
(*) I do like to be beside the seaside 41. Which of the following will remove a trigger in your schema named EMP_TRIGG from the database? Mark for Review (1) Points DROP emp_trigg TRIGGER; ALTER TRIGGER emp_trigg DISABLE; DROP TRIGGER emp_trigg; (*) REMOVE TRIGGER emp_trigg; None of the above Incorrect. Refer to Section 10. 42. Examine the following code: CREATE TRIGGER emp_trigg AFTER UPDATE OF salary ON employees FOR EACH ROW DECLARE v_count NUMBER; BEGIN -- Line A END; Which of the following statements is NOT allowed at Line A? Mark for Review (1) Points SELECT count(*) INTO v_count FROM departments; UPDATE employees SET job_id = 'IT_PROG' WHERE employee_id = :OLD.employee_id; SELECT count(*) INTO v_count FROM employees; (*) DBMS_OUTPUT.PUT_LINE('A salary was updated'); None. All of the above are allowed. Incorrect. Refer to Section 10. 43. A trigger can be created in the database or within an application. True or F alse? Mark for Review (1) Points True (*) False
Incorrect. Refer to Section 10. 44. A DML statement trigger fires only once for each triggering DML statement, w hile a row trigger fires once for each row processed by the triggering statement . True or False? Mark for Review (1) Points True (*) False Incorrect. Refer to Section 10. 45. INSTEAD OF triggers are always row triggers, even if FOR EACH ROW is omitted . True or False? Mark for Review (1) Points True (*) False Incorrect. Refer to Section 10.
Section 11 46. Package ED_PACK has declared a record type named ED_TYPE in the package spec ification. Which of the following anonymous blocks successfully declares a varia ble whose datatype is ED_TYPE? Mark for Review (1) Points DECLARE v_ed_rec IS RECORD ed_pack.ed_type; BEGIN ... DECLARE v_ed_rec ed_pack.ed_type; BEGIN ... (*) DECLARE v_ed_rec ed_pack.ed_type%ROWTYPE; BEGIN... DECLARE v_ed_rec ed_pack.ed_type%TYPE; BEGIN ... None of the above. Variables of datatype ED_TYPE can be declared only within ED_
PACK, not in separate subprograms or anonymous blocks.
Incorrect. Refer to Section 11. 47. Which of the following PL/SQL data structures can store a collection? (Choos e two.) Mark for Review (1) Points (Choose all correct answers) An INDEX BY table (*) A record %ROWTYPE An INDEX BY table of records (*) A BLOB Incorrect. Refer to Section 11. 48. You have created several directory objects in the database, as pointers to o perating system directories which contain BFILEs. Which data dictionary view wou ld you query to see these directories? Mark for Review (1) Points USER_DIRECTORIES USER_BFILES ALL_DIRECTORIES (*) USER_EXTERNAL_FILES ALL_BFILES Incorrect. Refer to Section 11. 49. Which of the following best describes the difference between BLOB and BFILE data? Mark for Review (1) Points A BLOB can contain text data while a BFILE cannot. BLOB data is stored inside the database, while BFILE data is outside the databas e in separate operating system files. (*) The maximum size of a BLOB is 2GB; a BFILE can be up to 128TB if needed. A table can contain several BLOB columns but only one BFILE column. There is no difference between a BLOB and a BFILE.
Incorrect. Refer to Section 11.
Section 12 50. The PL/SQL variable V_LAST_NAME is used to store fetched values of the LAST_ NAME column of the EMPLOYEES table. To minimize dependency failures, the variabl e should be declared as: v_last_name VARCHAR2(25); True or False? Mark for Review (1) Points True False (*)