Test: Quiz: Introduction to Dependencies
1. Which of the following will NOT help to minimize dependency failures?
(Choose all correct answers)
a) SELECTing a list of column names instead of using SELECT * (*)
b) Declaring records using the %ROWTYPE attribute
c) Including a column list with INSERT statements
d) Declaring scalar variables with NOT NULL if the corresponding table column has a NOT
NULL constraint (*)
e) Declaring scalar variables using the %TYPE attribute
2. A procedure show_emps contains the following declaration:
CURSOR emp_curs IS SELECT last_name, salary FROM employees;
What will happen to the procedure if a new column is added to the employees table?
a)The procedure will still be valid and execute correctly because it does not reference the
added column.
b)The procedure will automatically be dropped and must be recreated.
c)The procedure will be marked invalid and must be recompiled before it can be reexecuted.
(*)
d)Users' privileges to execute the procedure will automatically be revoked.
3. View dept_view is based on a select from table departments. Procedure show_dept contains code
which selects from dept_view. Which of the following statements are true? (Choose three.)
a)departments is indirectly dependent on show_dept
b)show_dept is directly dependent on dept_view (*)
c)dept_view is directly dependent on departments (*)
d)show_dept is indirectly dependent on departments (*)
e)emp_view is directly dependent on show_dept
4. User ALICE owns a procedure show_emps which references table employees.
Which of the following will generate information that shows this dependency?
a)BEGIN deptree_fill('TABLE','EMPLOYEES');
END;
b)BEGIN deptree_fill('PROCEDURE','ALICE','SHOW_EMPS');
END;
c)BEGIN deptree_fill('ALICE','TABLE','EMPLOYEES');
END;
d)BEGIN deptree_fill('TABLE','ALICE','EMPLOYEES');
END;(*)
e)BEGIN deptree_fill('ALICE','PROCEDURE','SHOW_EMPS');
END;
5. Package emp_pack contains two public procedures: get_emps and upd_emps. A separate procedure
emp_proc invokes emp.pack.get_emps. The upd_emps package body code is now altered, and the
package body (but not the package specification) is recreated.Emp_proc will be marked invalid and
needs to be recompiled.
True or False?
a)True
b)False (*)
6. Which of the following statements will show whether procedure myproc is valid or invalid?
a)SELECT status FROM USER_OBJECTS
WHERE object_type = 'PROCEDURE'
AND object_name = 'MYPROC';
(*)
b)SELECT status FROM USER_PROCEDURES
WHERE procedure_name = 'MYPROC';
c)SELECT valid FROM USER_OBJECTS
WHERE object_type = 'PROCEDURE'
AND object_name = 'MYPROC';
SELECT * FROM deptree;
7. A SELECT from DEPTREE produced the following output.>
NESTED_LEVEL TYPE NAME
0 TABLE EMPLOYEES
1 VIEW EMP_VW
2 PROCEDURE ADD_EMP
1 PROCEDURE QUERY_EMP
What dependencies does this show? (Choose three.)
a)QUERY_EMP is directly dependent on EMPLOYEES (*)
b)ADD_EMP is directly dependent on EMPLOYEESADD_EMP is directly depedent on EMP_VW
(*)
c)QUERY_EMP is directly dependent on ADD_EMP
d)EMP_VW is directly dependent on EMPLOYEES (*)
8. Which of the following database objects are created when the utldtree.sql script is run? (Choose
three.)
a)The utldtree table
b)The deptree_temptab table (*)
c)The deptree and ideptree views (*)
d)The deptree table
e)The deptree_fill procedure (*)
9. Procedure get_depts has been marked invalid because one of the objects it references has been
altered. Which of the following statements are true? (Choose two.)
a)The procedure will be recompiled automatically the next time it is invoked. The recompilation will
always be successful.
b)The procedure will be recompiled automatically the next time it is invoked. The recompilation may
or may not be successful.(*)
c)The procedure can be recompiled manually by: ALTER PROCEDURE get_depts COMPILE;(*)
d)The procedure can be recompiled manually by: ALTER PROCEDURE get_depts RECOMPILE;
e)The procedure does not need to be recompiled.
10. A procedure includes the following code:
SELECT first_name, salary INTO v_first_name, v_salary
FROM employees WHERE employee_id = 100;
Which of the following changes to the employees table will allow the procedure to be recompiled
successfully ? (Choose two.)
a)The table is dropped but a public table exists with the same name and st
ructure. (*)
b)The table is dropped.
c)A new column is added to the table. (*)
d)The table name is changed to newemps.
e)The first_name column is dropped from the table.
11. A single PL/SQL subprogram such as a procedure can be both a referenced object and a dependent
object. True or False?
True (*)
False
12. The IDEPTREE view shows dependencies by indenting the lines of output instead of by using a
NESTED_LEVEL column. True or False?
True (*)
False
13. Which data dictionary view shows information about references and dependencies?
a)DEPTREE
b)USER_DEPENDENCIES (*)
c)USER_REFERENCES
d)USER_LOCAL_DEPENDENCIES
14. PL/SQL procedure A invokes procedure B, which in turn invokes procedure C, which references
table T. If table T is dropped, which of the following statements is true?
a)C is invalid but A and B are still valid
b)A, B and C are all invalid (*)
c)B and C are invalid but A is still valid
d)A, B and C are all still valid
e)None of the above
Test: Quiz: Understanding Remote Dependencies
1. In Signature Mode, a procedure will not compile if the signatures of the remote dependencies do not
match. True or False?
a)True (*)
b)False
2. In this scenario, the following status is given for each procedure:
Procedure A is local and has a time stamp of 10 AM
Procedure B is remote and has a local time stamp of 5 AM and has a remote time stamp of 4 AM
In Timestamp Mode, Procedure A will execute successfully at 11 AM. True or False?
a)True
b)False (*)
3. In Signature Mode, a compiled procedure is still valid if its dependent procedure has a parameter
data type change from NUMBER to INTEGER.
a)True (*)
b)False
4. The Data Dictionary controls the remote dependency mode. True or False?
a)True
b)False (*)
5. A remote dependency is when a dependent object resides on a database on a separate node. True or
False?
True (*)
False
6. In this scenario, the following status is given for each procedure:
Procedure A is local, executed, and invalidated because the remote Procedure B time stamp does not
match the local time stamp for Procedure B
Procedure A is recompiled.In Timestamp Mode, now Procedure A will execute successfully. True or
False?
a)True (*)
b)False
7. With remote dependencies, one master data dictionary that resides on one server identifies the status
of all schema objects. True or False?
a)True
b)False (*)
8. Which statement for setting a database parameter is the default for remote dependency checking?
a)ALTER SESSION SET REMOTE_DEPENDENCIES_MODE = TIMESTAMP (*)
b)ALTER SESSION SET REMOTE_DEPENDENCIES_MODE = SIGNATUREALTER SESSION
REMOTE_DEPENDENCIES_MODE = TIMESTAMP
c)ALTER SESSION REMOTE_DEPENDENCIES_MODE = SIGNATURE
Section 15
Test: Quiz: Using the PL/SQL Initialization Paraeters
1. When setting PLSQL_OPTIMIZE_LEVEL = 2, the compiled code will remove
code and exceptions that can never be executed. True or False?
True(*)
False
2. To set the PLSQL_CODE_TYPE to its fastest execution speed, which
command do you use?
ALTER SYSTEM SET PLSQL_CODE_TYPE=NATIVE;
ALTER SYSTEM SET PLSQL_CODE_TYPE=2;
ALTER SESSION SET PLSQL_CODE_TYPE = NATIVE; (*)
ALTER SESSION SET PLSQL_CODE_TYPE = INTERPRETED;
ALTER SESSION SET PLSQL_CODE_TYPE = 2;
3. PLSQL_CODE_TYPE determines the type of code for PL/SQL code and for
SQL statements, which is what speeds up the execution speed. True or
False?
True
False (*)
4. Which data dictionary view allows you to see the setting for
PLSQL_OPTIMIZE_LEVEL?
USER_PLSQL_OBJECTS
USER_PLSQL_OPTIMIZE
USER_PLSQL_OBJECT_SETTINGS (*)
USER_OBJECT_SETTINGS
USER_PLSQL_CODE_TYPE
5. Which are NOT examples of benefits of using PLSQL_OPTIMIZE_LEVEL.
(Choose two)
Control what PL/SQL does with useless code.
Combining compiled code from one subprogram into another
subprogram.
Separating compiled code so that separate units may be repeated as
needed. (*)
Backward compatible with previous versions of the Oracle database.
Modify source code to optimize frequently-used elements at the top. (*)
6. What are the valid values for PLSQL_OPTIMIZE_LEVEL in the data
dictionary?
0,1,2,3 (*)
0,1,2,3,4
1,2,3
1,2,3,4
Test: Quiz: Displaying Compiler Warning Messages
1. Which PL/SQL warning message identifies code that can cause unexpected behaviour or wrong
results when executed?
INFORMATIONAL
PERFORMANCE
ALL
SEVERE (*)
ERROR
2. A warning in PL/SQL is the same as an error in PL/SQL, but can only be viewed through the
USER_ERRORS data dictionary view. True or False?
True
False (*)
3. The two statements below are equivalent. True or False?
DBMS_WARNING.ADD_WARNING_SETTING_CAT
('INFORMATIONAL','ENABLE','SESSION'); and ALTER SESSION
SET PLSQL_WARNINGS = 'ENABLE:INFORMATIONAL';
True (*)
False
4. The informational warning level for PL/SQL compiled code identifies thecode that may cause
execution speed to be slow. True or False?
True
False (*)
5. An error in PL/SQL is when the compiler does not proceed successfully and an error message is
displayed. True or False?
True (*)
False
6. Which pair of DBMS_WARNING commands would allow you to obtain the current settings and
change and restore those settings in a PL/SQL subprogram? (Choose two)
DBMS_WARNING.SET_WARNING_SETTING_STRING (*)
DBMS_WARNING.ADD_WARNING_SETTING_CAT
DBMS_WARNING.GET_WARNING_SETTING_STRING (*)
DBMS_WARNING.GET_WARNING_STRING
Test: Quiz: Using Conditional Compilation
1. Conditional compilation allows you to include extra code to help with debugging, which can be
removed once errors are resolved. True or False?
True (*)
False
2. The value of DBMS_DB_VERSION.VER_LE_11 is TRUE when the version of the Oracle
database is version 11 or greater. True or False?
True
False (*)
3. If the version and release of the Oracle database in use is 10.2, what statement will allow syntax
available in version 10.2 or later?
$IF DBMS_DB_VERSION.VER_LE_10_2 $THEN -- some messaage
$ELSE -- some action
$END
$IF DBMS_DB_VERSION.VER_LE_10_2 $THEN -- some messaage
$ELSE -- some action
$END;
$IF DBMS_DB_VERSION.VER_LE_10_1 $THEN -- some messaage
$ELSE -- some action
$END
(*)
$IF DBMS_DB_VERSION.VER_LE_10_1 $THEN -- some messaage
$ELSE -- some action
$END;
4. Identify the selection directives used in conditional compilation.
$IF
$THEN
$ELSE
$END
$CCFLAG
$$IF
$$THEN
$$ELSE
$$ELSIF
$$END
$IF
$THEN
$ELSE $ELSIF
$ENDIF
$IF
$THEN
$ELSE
$ELSIF
$END
(*)
$$IF
$$THEN
$$ELSE
$$END
$$DEBUG
5. You can choose which code to include in a PL/SQL program based on conditional compilation
directives. True or False?
True (*)
False
6. Inquiry directives are used to selectively include or exclude PL/SQL code based on values of pre-
defined variables that are set using the PLSQL_CCFLAGS parameter. True or False?
True
False (*)
Test: Quiz:Hiding your Source Code
1. Obfuscation allows the owner to see the source code, but not the users to whom EXECUTE
privileges have been granted. True or False?
True
False (*)
2. When wrapping subprograms, the entire PL/SQL code must be included as an IN argument with
data type VARCHAR2 up to 32,767 characters. True or False?
True (*)
False
3. To obfuscate the procedure my_proc, what statement should be at Line A?
BEGIN
-- Line A
('CREATE OR REPLACE PROCEDURE mycleverproc (p_param1 IN NUMBER, p_param2 OUT
NUMBER) IS BEGIN ... /* some clever but private code here */
END mycleverproc;');
END;
DBMS_DML.CREATE_WRAP
DBMS_DDL.CREATE_WRAP
DBMS_DDL.CREATE_WRAPPED (*)
DBMS_DDL.WRAPPED
DBMS_DDL.WRAP_CODE
4. To create obfuscated code using the wrapper utility, determine the order in which to execute the
following steps.
A Connect to the database and execute the wrapped text file as a script to compile the wrapped code
into the Data Dictionary.
B Log into the database server computer.
C Create a text file containing your complete unwrapped source code.
D Execute WRAP to create a second text file containing the wrapped code.
A,B,C,D
B,C,D,A (*)
C,D,A,B
C,A,B,D
B,D,C,A
5. For PL/SQL code larger than 32,767 characters, you must use the wrap utility. True or False?
True (*)
False
6. One benefit of obfuscation is to protect intellectual property written in PL/SQL. True or False?
True (*)
False