Self Test   303
SELF TEST
The following questions will help you measure your understanding of the material presented in this
chapter. Read all the choices carefully because there may be more than one correct answer. Choose
all the correct answers for each question.
Describe the Group Functions
 1. What result is returned by the following statement?
    SELECT COUNT(*) FROM DUAL; (Choose the best answer.)
    A. NULL
    B. 0
    C. 1
    D. None of the above
 2. Choose one correct statement regarding group functions.
    A. Group functions may only be used when a GROUP BY clause is present.
    B. Group functions can operate on multiple rows at a time.
    C. Group functions only operate on a single row at a time.
    D. Group functions can execute multiple times within a single group.
Identify the Available Group Functions
 3. What value is returned after executing the following statement?
    SELECT SUM(SALARY) FROM EMPLOYEES;
    Assume there are 10 employee records and each contains a SALARY value of 100, except for 1,
    which has a null value in the SALARY field. (Choose the best answer.)
    A. 900
    B. 1000
    C. NULL
    D. None of the above
 4. Which values are returned after executing the following statement?
    SELECT COUNT(*), COUNT(SALARY) FROM EMPLOYEES;
    Assume there are 10 employee records and each contains a SALARY value of 100, except for 1,
    which has a null value in their SALARY field. (Choose all that apply.)
    A. 10 and 10
    B. 10 and NULL
    C. 10 and 9
    D. None of the above
304    Chapter 6:   Reporting Aggregated Data Using the Group Functions
5. What value is returned after executing the following statement?
   SELECT AVG(NVL(SALARY,100)) FROM EMPLOYEES;
   Assume there are ten employee records and each contains a SALARY value of 100, except for
   one employee, who has a null value in the SALARY field. (Choose the best answer.)
   A. NULL
   B. 90
   C. 100
   D. None of the above
Group Data Using the GROUP BY Clause
6. What value is returned after executing the following statement?
   SELECT SUM((AVG(LENGTH(NVL(SALARY,0)))))
   FROM EMPLOYEES
   GROUP BY SALARY;
   Assume there are ten employee records and each contains a SALARY value of 100, except for
   one, which has a null value in the SALARY field. (Choose the best answer.)
   A. An error is returned
   B. 3
   C. 4
   D. None of the above
7. How many records are returned by the following query?
   SELECT SUM(SALARY), DEPARTMENT_ID FROM EMPLOYEES
   GROUP BY DEPARTMENT_ID;
   Assume there are 11 nonnull and 1 null unique DEPARTMENT_ID values. All records have a
   nonnull SALARY value. (Choose the best answer.)
   A. 12
   B. 11
   C. NULL
   D. None of the above
8. What values are returned after executing the following statement?
   SELECT JOB_ID, MAX_SALARY FROM JOBS GROUP BY MAX_SALARY;
   Assume that the JOBS table has ten records with the same JOB_ID value of DBA and the same
   MAX_SALARY value of 100. (Choose the best answer.)
   A. One row of output with the values DBA, 100
   B. Ten rows of output with the values DBA, 100
   C. An error is returned
   D. None of the above
                                                                              Lab Question   305
Include or Exclude Grouped Rows Using the HAVING Clause
 9. How many rows of data are returned after executing the following statement?
    SELECT DEPT_ID, SUM(NVL(SALARY,100)) FROM EMP
    GROUP BY DEPT_ID HAVING SUM(SALARY) > 400;
    Assume the EMP table has ten rows and each contains a SALARY value of 100, except for one,
    which has a null value in the SALARY field. The first and second five rows have DEPT_ID
    values of 10 and 20, respectively. (Choose the best answer.)
    A. Two rows
    B. One row
    C. Zero rows
    D. None of the above
10. How many rows of data are returned after executing the following statement?
    SELECT DEPT_ID, SUM(SALARY) FROM EMP GROUP BY DEPT_ID HAVING
    SUM(NVL(SALARY,100)) > 400;
    Assume the EMP table has ten rows and each contains a SALARY value of 100, except for one,
    which has a null value in the SALARY field. The first and second five rows have DEPT_ID
    values of 10 and 20, respectively. (Choose the best answer.)
    A. Two rows
    B. One row
    C. Zero rows
    D. None of the above
LAB QUESTION
Using SQL Developer or SQL*Plus, connect to the OE schema and complete the following tasks.
   The PRODUCT_INFORMATION table lists items that are orderable and others that are
planned, obsolete, or under development. You are required to prepare a report that groups the non-
orderable products by their PRODUCT_STATUS and shows the number of products in each group
and the sum of the LIST_PRICE of the products per group. Further, only the group-level rows, where
the sum of the LIST_PRICE is greater than 4000, must be displayed. A product is nonorderable if the
PRODUCT_STATUS value is not equal to the string orderable. There are several approaches to
solving this question. Your approach may differ from the solution proposed.