Использование вопросов о групповых функциях
1. Which of the following is NOT a GROUP BY function?
- MAX
- MIN
- NVL
- AVG
Answer: C. NVL - это общая функция, используемая для предоставления альтернативного значения NULL-значениям. Функции MAX, MIN и AVG могут использоваться как функции GROUP BY.
2. Which of the following functions can be used without GROUP BY clause in SELECT query?
- COUNT
- MAX
- MIN
- AVG
Answer: A, B, C, D. Все перечисленные групповые функции могут использоваться в запросе при условии, что в запросе SELECT не выбраны другие столбцы.
3. Which of the following SELECT query returns the department number with maximum salary compensated to an employee? (Consider the table structure as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT department_id , max(salary ) FROM employees ;
SELECT department_id , max(salary ) FROM employees GROUP BY department_id ;
SELECT max(salary ) FROM employees GROUP BY department_id ;
SELECT max(salary ) FROM employees ;
Answer: B. Функцию MAX можно использовать для возврата максимальной заработной платы в отделе, где каждая группа формируется отделом.
4. Which of the following statements are true about the COUNT function?
- Функция COUNT подсчитывает количество строк
- Функция COUNT (*) подсчитывает количество строк с дубликатами и значениями NULL.
- Функция COUNT (DISTINCT) подсчитывает количество отдельных строк
- COUNT (*) эквивалентно COUNT (ALL)
Answer: B. COUNT (*) подсчитывает количество строк, включая дубликаты и NULL. Используйте ключевое слово DISTINCT и ALL, чтобы ограничить повторяющиеся значения и значения NULL.
5. What are the appropriate data types accepted by GROUP BY functions?
- Вложенные таблицы
- NUMBER
- CLOB
- DATE
Answer: B. Типы данных для функций с аргументом могут быть CHAR, VARCHAR2, NUMBER или DATE.
6. A table T_COUNT has 12 number values as 1, 2, 3, 32, 1, 1, null, 24, 12, null, 32, null. Predict the output of the below query.
SELECT COUNT (*) FROM t_count;
- 12
- 6
- 9
- Выдает исключение, потому что функция COUNT не работает со значениями NULL
Answer: A. COUNT (*) подсчитывает количество строк, включая дубликаты и NULL. Используйте ключевое слово DISTINCT и ALL, чтобы ограничить повторяющиеся значения и значения NULL.
7. A table T_COUNT has 12 number values as 1, 2, 3, 32, 1, 1, null, 24, 12, null, 32, null. Predict the output of the below query.
SELECT COUNT (num) FROM t_count;
- 12
- 6
- 9
- Выдает исключение, потому что функция COUNT не работает со значениями NULL
Answer: C. COUNT (столбец) игнорирует значения NULL, но считает дубликаты.
8. A table T_COUNT has 12 number values as 1, 2, 3, 32, 1, 1, null, 24, 12, null, 32, null. Predict the output of the below query.
SELECT COUNT (ALL num) FROM t_count;
- 12
- 6
- 9
- Выдает исключение, потому что функция COUNT не работает со значениями NULL
Answer: C. СЧЕТЧИК (ВСЕ столбец) игнорирует значения NULL, но считает дубликаты.
9. A table T_COUNT has 12 number values as 1, 2, 3, 32, 1, 1, null, 24, 12, null, 32, null. Predict the output of the below query.
SELECT COUNT (DISTINCT num) FROM t_count;
- 12
- 6
- 9
- Выдает исключение, потому что функция COUNT не работает со значениями NULL
Answer: B. COUNT (DISTINCT столбец) подсчитывает отдельные ненулевые значения.
10. What happens when the below query is executed in SQL* Plus?
SELECT COUNT() FROM dual;
- Выполняется успешно и не возвращает результатов
- Выполняется успешно и возвращает значение «1»
- Выдает исключение «ORA-00909: недопустимое количество аргументов»
- Выдает исключение «ORA-00904:« COUNT »: недопустимый идентификатор», потому что функция COUNT не работает с таблицей DUAL.
Answer: C. Функция COUNT требует минимум одного аргумента, которым может быть столбец с [ALL | DISTINCT] или '*'.
11. Here are few statements about VARIANCE function in SQL.
я. Функция принимает несколько числовых входов и возвращает дисперсию всех значений.
II. Функция принимает числовой столбец и возвращает дисперсию всех значений столбца, включая NULL.
iii. Функция принимает числовой столбец и возвращает дисперсию всех значений столбца, исключая NULL.
Выберите правильную комбинацию из представленных ниже вариантов.- я и iii
- я и II
- ii
- iii
Answer: C. Функция VARIANCE принимает один числовой аргумент в качестве имени столбца и возвращает дисперсию всех значений столбца с учетом NULL.
12. Which of the following is NOT a GROUP BY extensions in SQL?
- ГРУППА ПО
- НАБОРЫ ГРУППИРОВКИ
- CUBE
- ROLLUP
Answer: A. Операции GROUPING SETS можно использовать для выполнения нескольких агрегатов GROUP BY с помощью одного запроса.
13. Select the correct statements about the below query. Consider the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT department_id , SUM(salary )
FROM employees
GROUP BY department_id ;
- SUM - это группа по функциям, потому что она обрабатывает группу сотрудников, работающих в отделе
- СУММ - это агрегатная функция, поскольку она дает один результат для каждой группы данных.
- SUM - это функция с одной строкой, потому что она возвращает одно значение для группы, т.е. отдела
- SUM - это функция группировки по расширению, поскольку она использует предложение GROUP BY для логической группировки отделов.
Answer: A. СУММ - это групповая функция, которая вычисляет сумму зарплат группы сотрудников, работающих в отделе.
14. Which clause is used to filter the query output based on aggregated results using a group by function?
- WHERE
- LIMIT
- ГРУППА ГДЕ
- HAVING
Answer: D. Предложение HAVING используется для ограничения результатов группы. Вы используете предложение HAVING, чтобы указать группы, которые должны отображаться, тем самым дополнительно ограничивая группы на основе совокупной информации. Предложение HAVING может предшествовать предложению GROUP BY, но рекомендуется сначала разместить предложение GROUP BY, поскольку оно более логично. Группы формируются, и групповые функции вычисляются до применения предложения HAVING к группам в списке SELECT.
15. Examine the given table structure and predict the outcome of the following query.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT count(*)
FROM employees
WHERE comm = NULL;
- Запрос возвращает количество сотрудников, у которых нет комиссии
- Запрос вызывает ошибку, поскольку знак равенства не может использоваться при поиске значения NULL.
- Запрос возвращает количество сотрудников в отделе, комиссия которых равна NULL.
- Запрос выдает ошибку, потому что в запросе отсутствует предложение GROUP BY.
Answer: B. Исключение значений NULL с помощью условия WHERE - это способ заставить запрос игнорировать значения NULL. Но здесь использование оператора IS NULL неверно. Условие должно быть «WHERE comm IS NULL».
16. Which of the following statements is true about the group functions?
- Функцию MIN можно использовать только с числовыми данными.
- Функцию MAX можно использовать только со значениями даты.
- Функцию AVG можно использовать только с числовыми данными.
- Функция СУММ не может быть частью вложенной функции.
Answer: C. Функцию AVG можно использовать только с числовыми значениями. Другие функции, которые имеют такое ограничение, - это SUM, STDDEV и VARIANCE.
17. Which of the following is a valid SELECT statement?
SELECT AVG(retail-cost) FROM books GROUP BY category;
SELECT category, AVG(retail-cost) FROM books;
SELECT category, AVG(retail-cost) FROM books WHERE AVG(retail-cost) > 8.56 GROUP BY category;
SELECT category, AVG(retail-cost) Profit FROM books GROUP BY category HAVING profit > 8.56;
Answer: A. Псевдонимы столбцов нельзя использовать в предложениях GROUP BY или HAVING.
18. Which of the following statements is correct?
- Предложение WHERE может содержать групповую функцию только в том случае, если функция также не указана в предложении SELECT.
- Групповые функции нельзя использовать в предложениях SELECT, FROM или WHERE.
- Предложение HAVING всегда обрабатывается перед предложением WHERE.
- Предложение GROUP BY всегда обрабатывается перед предложением HAVING.
Answer: D. Хотя Oracle не вызывает ошибку, если предложение HAVING предшествует предложению GROUP BY, но оно обрабатывается только после того, как предложение GROUP BY обработано и группа готова к фильтрации.
19. Which of the following is not a valid SQL statement?
SELECT MIN(pubdate) FROM books GROUP BY category HAVING pubid = 4;
SELECT MIN(pubdate) FROM books WHERE category = 'COOKING';
SELECT COUNT(*) FROM orders WHERE customer# = 1005;
SELECT MAX(COUNT(customer#)) FROM orders GROUP BY customer#;
Answer: A.
20. Which of the following statements is correct?
- Функция COUNT может использоваться для определения количества строк, содержащих значение NULL.
- В групповые функции включаются только отдельные значения, если ключевое слово ALL не включено в предложение SELECT.
- Предложение WHERE ограничивает обрабатываемые строки.
- Предложение HAVING определяет, какие группы будут отображаться в результатах запроса.
Answer: C, D. Предложение WHERE ограничивает строки до того, как они будут сгруппированы и обработаны, а предложение HAVING ограничивает группы.
21. Which of the following is a valid SQL statement?
SELECT customer#, order#, MAX(shipdate-orderdate) FROM orders GROUP BY customer# WHERE customer# = 1001;
SELECT customer#, COUNT(order#) FROM orders GROUP BY customer#;
SELECT customer#, COUNT(order#) FROM orders GROUP BY COUNT(order#);
SELECT customer#, COUNT(order#) FROM orders GROUP BY order#;
Answer: B. Предложение GROUP BY должно содержать все столбцы, кроме того, который используется внутри групповой функции.
22. Which of the following SELECT statements lists only the book with the largest profit?
SELECT title, MAX(retail-cost) FROM books GROUP BY title;
SELECT title, MAX(retail-cost) FROM books GROUP BY title HAVING MAX(retail-cost);
SELECT title, MAX(retail-cost) FROM books;
- Ни один из вышеперечисленных
Answer: A.
23. Which of the following statement(s) is/are correct?
1. Групповая функция может быть вложена в групповую функцию.
2. Групповая функция может быть вложена в однорядную функцию.
3. Однострочная функция может быть вложена в групповую функцию.
- 1
- 2
- 3
- 1 и 3
Answer: A, B, C. Групповые функции могут быть вложены только на глубину до двух. Групповые функции могут быть вложены в однорядные функции (AVG встроен в функцию TO_CHAR). Кроме того, однорядные функции могут быть вложены в групповые функции.
24. Which of the following functions is used to calculate the total value stored in a specified column?
- COUNT
- ADD
- TOTAL
- SUM
Answer: D. Функция СУММ используется для сложения числовых значений.
25. Which of the following SELECT statements lists the highest retail price of all books in the Family category?
SELECT MAX(retail) FROM books WHERE category = 'FAMILY';
SELECT MAX(retail) FROM books HAVING category = 'FAMILY';
SELECT retail FROM books WHERE category = 'FAMILY' HAVING MAX(retail);
- Ни один из вышеперечисленных
Answer: A. Поскольку категория FAMILY должна быть ограничена перед группировкой, строки таблицы должны быть отфильтрованы с помощью предложения WHERE, а не HAVING.
26. Which of the following functions can be used to include NULL values in calculations?
- SUM
- NVL
- MAX
- MIN
Answer: B.NVL - это общая функция для предоставления альтернативных значений значениям NULL. Это действительно может иметь значение в арифметических вычислениях с использованием групповых функций AVG, STDDEV и VARIANCE.
27. Which of the following is not a valid statement?
- Вы должны ввести ключевое слово ALL в групповую функцию, чтобы включить все повторяющиеся значения.
- Функцию AVG можно использовать для нахождения средней рассчитанной разницы между двумя датами.
- Функции MIN и MAX можно использовать для столбцов VARCHAR2.
- Все вышеперечисленное
Answer: A. Ключевое слово ALL учитывает дубликаты, но игнорирует NULL. Дубликаты также включены в указание "*" и имени столбца.
28. Which of the following SQL statements determines how many total customers were referred by other customers?
SELECT customer#, SUM(referred) FROM customers GROUP BY customer#;
SELECT COUNT(referred) FROM customers;
SELECT COUNT(*) FROM customers;
SELECT COUNT(*) FROM customers WHERE referred IS NULL;
Answer: B. Если рассматривать всех клиентов как одну группу, COUNT (привлечено) будет учитывать только тех, кого кто-то направил. COUNT (указано) игнорирует значения NULL в столбце.
29. Determine the correct order of execution of following clauses in a SELECT statement.
1. ВЫБРАТЬ
2. ОТ
3.ГДЕ
4. ГРУППА ПО
5. ИМЕЕТ
6. ЗАКАЗАТЬ
- 2-3-4-5-1-6
- 1-2-3-4-5-6
- 6-5-4-3-2-1
- 5-4-2-3-1-6
Answer: A. Порядок обработки начинается с предложения FROM для получения имен таблиц, затем ограничиваются строки с помощью предложения WHERE, группируются с помощью предложения GROUP BY, ограничиваются группы с помощью предложения HAVING. Предложение ORDER BY является последним, которое обрабатывается для сортировки окончательного набора данных.
30. Which of the below clauses is used to group a set of rows based on a column or set of columns?
- HAVING
- WHERE
- ГРУППА ПО
- GROUPING
Answer: C. Предложение GROUP BY формирует группы данных на основе указанного списка столбцов.
31. Which of the following group functions can be used for population variance and population standard deviation problems?
- VAR_POP
- STDDEV_POP
- VARIANCE
- STDDEV_SASMP
Answer: A, B.
32. Select the positions in a SELECT query where a group function can appear.
- Оператор SELECT
- Предложение WHERE
- Предложение ORDER BY
- Предложение GROUP BY
Answer: A, C, D. Групповые функции могут появляться в предложениях SELECT, ORDER BY и HAVING. Oracle вызывает исключение, если групповые функции используются в предложениях WHERE или GROUP BY.
33. Examine the structure of the EMPLOYEES table as given. Which query will return the minimum salary in each department?
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT department_id , MIN (salary ) from EMPLOYEES ;
SELECT department_id , MIN (salary ) from EMPLOYEES GROUP BY department_id ;
SELECT department_id , MIN (salary ) from EMPLOYEES GROUP BY salary ;
SELECT department_id , MIN (salary ) from EMPLOYEES GROUP BY employee_id ;
Answer: B. Функция MIN возвращает минимальную зарплату в группе, сформированной по отделам.
34. Examine the structure for the table EMPLOYEES and Interpret the output of the below query
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT COUNT(*), COUNT(all comm) FROM employees ;
- Это вызывает ошибку, потому что в запросе может использоваться только одна агрегатная функция.
- Это вызывает ошибку, потому что предложение GROUP BY отсутствует.
- Он выполняется успешно и возвращает одинаковые значения для обоих.
- Он успешно выполняется там, где COUNT (*), включая NULL, и COUNT (все сообщения), исключая NULL.
Answer: D.
35. Which of the following are true about group functions?
- Вы можете использовать групповые функции в любом предложении оператора SELECT.
- Вы можете использовать групповые функции только в списке столбцов предложения select и в предложении WHERE оператора SELECT.
- Вы можете смешивать столбцы с одной строкой с функциями группировки в списке столбцов оператора SELECT, группируя столбцы с одной строкой.
- Вы можете передавать имена столбцов, выражения, константы или функции в качестве параметра групповой функции.
Answer: C. Групповые функции могут быть вложены только на глубину до двух. Групповые функции могут быть вложены в однорядные функции (AVG встроен в функцию TO_CHAR). Кроме того, однорядные функции могут быть вложены в групповые функции.
36. Examine the structure of the table EMPLOYEES as given. You want to create a "emp_dept_sales" view by executing the following SQL statements.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
CREATE VIEW emp_dept_sales
AS
SELECT d.department_name , sum(e.salary )
FROM employees e, departments d
where e.department_id =d.department_id
GROUP by d.department_name ;
Какое утверждение верно в отношении выполнения приведенного выше утверждения?
- Представление будет создано, и вы сможете выполнять с ним операции DLM.
- Представление не будет создано, поскольку операторы соединения не разрешены для создания представления
- Представление не будет создано, поскольку предложение GROUP BY не разрешено для создания представления.
- Представление будет создано, но операции DML с ним не будут разрешены.
Answer: D. Правила выполнения операций DML с видом. Вы не можете добавлять данные через представление, если оно включает групповые функции или предложение GROUP BY или ключевое слово DISTINCT. Псевдостолбец ROWNUM ключевое слово Столбцы, определенные выражениями NOT NULL, столбцы в базовых таблицах, которые не выбраны представлением.
37. Which of the following statements are true regarding views?
- Подзапрос, определяющий представление, не может включать предложение GROUP BY
- Представление создается с подзапросом, содержащим ключевое слово DISTINCT, которое может быть обновлено
- Операция на языке манипулирования данными (DML) может выполняться в представлении, созданном с помощью подзапроса, имеющего все столбцы таблицы NOT NULL.
- Представление, созданное с помощью подзапроса с ключевым словом ROWNUM псевдостолбца, не может быть обновлено
Answer: C, D. Правила выполнения операций DML с видом. Вы не можете добавлять данные через представление, если оно включает групповые функции или предложение GROUP BY или ключевое слово DISTINCT. Псевдостолбец ROWNUM ключевое слово Столбцы, определенные выражениями NOT NULL, столбцы в базовых таблицах, которые не выбраны представлением.
38. Examine the table structure as given.
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
Какое предложение в приведенном ниже запросе SQL вызывает ошибку?
SELECT department_id , avg(salary )
FROM departments
WHERE upper(job) in ('SALES','CLERK')
GROUP BY job
ORDER BY department_id ;
- WHERE
- SELECT
- СОРТИРОВАТЬ ПО
- ГРУППА ПО
Answer: D. Предложение GROUP BY должно содержать все столбцы, появляющиеся в операторе SELECT. Это вызывает ошибку, потому что JOB не является выбранным столбцом. Он должен был использовать DEPARTMENT_ID вместо JOB.
39. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Какой из приведенных ниже запросов SELECT отобразит максимальную и минимальную заработную плату для каждой категории должностей?
SELECT job, MAX(salary ), MIN (salary ) FROM employees GROUP BY department_id ;
SELECT job, MAX(salary ), MIN (salary ) FROM employees GROUP BY job;
SELECT job, MAX(salary ), MIN (salary ) FROM employees ;
- Две агрегатные функции нельзя использовать вместе в операторе SELECT.
Answer: B. В операторе SELECT может присутствовать более одной групповой функции.
40. Consider the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Изучите ошибку в запросе ниже.
SELECT department_id
FROM employees
WHERE hiredate > '01-JAN-1985'
AND COUNT(*) > 2
GROUP by department_id
HAVING SUM (salary ) > 1000;
- Он успешно выполняется и дает требуемый результат.
- Это вызывает ошибку, потому что COUNT (*) также следует указать в предложении SELECT.
- Он выполняется успешно, но не дает результата, потому что вместо COUNT (*) следует использовать COUNT (prod_id).
- Это вызывает ошибку, потому что COUNT (*) должно быть только в предложении HAVING, а не в предложении WHERE.
Answer: D. Групповые функции нельзя использовать в предложении WHERE. Может появиться в предложениях SELECT, HAVING и ORDER BY.
41. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Предскажите результат запроса ниже
SELECT job, COUNT(employee_id ),sum(salary )
FROM employees
GROUP BY job
HAVING SUM (salary ) > 5000;
- Он выполняется успешно и отображает количество сотрудников в каждой категории должностей, но игнорирует предложение HAVING, поскольку «зарплата» отсутствует в предложении GROUP BY.
- Это вызывает ошибку, потому что предложение HAVING недопустимо.
- Это вызывает ошибку, потому что "зарплата" не включена в предложение GROUP BY.
- Он выполняется успешно и перечисляет количество сотрудников по каждой категории с суммой заработной платы более 5000.
Answer: D. Предложение HAVING ограничивает групповые результаты. Функция COUNT используется для подсчета, а SUM - для сложения числовых значений.
42. What is true of using group functions on columns that contain NULL values?
- Групповые функции для столбцов игнорируют значения NULL.
- Групповые функции для столбцов, возвращающих даты, включают значения NULL.
- Групповые функции для столбцов, возвращающих числа, включают значения NULL.
- Групповые функции для столбцов нельзя точно использовать для столбцов, содержащих значения NULL.
Answer: A. За исключением функции COUNT, все групповые функции игнорируют значения NULL.
43. Which of the following statetments are true about the usage of GROUP BY columns in a subquery?
- Подзапросы могут содержать предложения GROUP BY и ORDER BY.
- Подзапросы не могут содержать предложения GROUP BY и ORDER BY.
- Подзапросы могут содержать ORDER BY, но не предложение GROUP BY.
- Подзапросы не могут содержать ORDER BY, но могут иметь предложение GROUP BY.
Answer: A. Как и основной запрос, подзапрос может содержать предложение GROUP BY, а также предложение ORDER BY.
Examine the table structure as given and answer the questions 44 to 49 that follow.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
44. Predict the outcome of the below query
SELECT avg(max(salary ))
FROM employees
GROUP BY department_id
HAVING avg(max(salary ))>100;
- Он успешно выполняется.
- Выдает ошибку, поскольку предложение HAVING недействительно.
- Выдает ошибку, потому что выражение GROUP BY недействительно.
- Это дает ошибку, потому что агрегатные функции не могут быть вложены в оператор SELECT.
Answer: B. Предложение HAVING не допускает вложения агрегатных функций.
45. Predict the output of the below query
SELECT avg(salary ), department_id
FROM employees
GROUP BY department_id ;
- Это дает ошибку, потому что агрегатная функция не может появляться сразу после предложения SELECT.
- Это дает ошибку, потому что предложение GROUP BY недействительно.
- Он выполняется без ошибок, но ничего не выводит.
- Он работает успешно и дает среднюю зарплату в каждом отделе.
Answer: D. Групповые функции могут использоваться в любой последовательности (до или после группировки по столбцам) в запросе SELECT.
46. Predict the output of the below query
SELECT lower(job),avg(salary )
FROM employees
GROUP BY upper(job);
- Он выполняется успешно и отображает «задание» в нижнем регистре.
- Он выполняется успешно, но в исходном случае отображает «задание».
- Это вызывает ошибку, потому что функция одной строки и агрегатные функции не могут использоваться вместе.
- Это вызывает ошибку, поскольку преобразование регистра в списке SELECT не совпадает с предложением GROUP BY преобразования регистра.
Answer: D. Функция LOWER, являющаяся функцией одной строки, должна быть указана в предложении GROUP BY, чтобы основать группировку данных EMPLOYEES.
47. Which of the below query executes successfully?
SELECT employee_id , COUNT(hiredate-sysdate) FROM employees ;
SELECT AVG(salary ), MAX(salary ) FROM employees ;
SELECT AVG(salary ), MAX(salary ) FROM employees GROUP BY department_id ;
SELECT AVG(hiredate) FROM employees ;
Answer: B, C. Первый запрос обрабатывает данные всех СОТРУДНИКОВ, а второй обрабатывает данные в группах отделов.
48. Identify the error in the below SELECT statement.
SELECT department_id , AVG (salary )
FROM employees
GROUP BY department_id
HAVING department_id > 10;
- Он успешно работает и отображает среднюю зарплату отделов выше 10.
- Это вызывает ошибку, потому что неагрегированный столбец не может использоваться в предложении HAVING.
- Он выполняется успешно, но показывает неверный результат для отделов.
- Это вызывает ошибку, потому что предложение HAVING должно быть помещено перед предложением GROUP BY.
Answer: A. Выражения GROUP BY могут использоваться в предложении HAVING для фильтрации групп из окончательного набора данных.
49. Predict the output of the below query
SELECT department_id , AVG (salary )
FROM employees
GROUP BY department_id
HAVING (department_id >10 and AVG(salary )>2000);
- Это вызывает ошибку, потому что в предложении HAVING нельзя указать несколько условий.
- Это вызывает ошибку, потому что неагрегированный столбец не может использоваться в предложении HAVING.
- Он успешно работает и отображает среднюю зарплату отдела выше 10 и выше 2000.
- Он выполняется успешно, но результат не отображается.
Answer: C. Предложение HAVING может налагать несколько условий, объединенных с помощью оператора AND или OR, фильтрующего группы.
50. Which of the following group functions can be used with DATE values?
- AVG
- MIN
- SUM
- COUNT
Answer: B, D. Групповые функции AVG и SUM могут использоваться только с числовыми данными.
51. Which of the following statements are true?
- AVG и SUM можно использовать только с числовыми типами данных.
- STDDEV и VARIANCE можно использовать только с числовыми типами данных.
- MAX можно использовать с типом данных LONG.
- MAX и MIN не могут использоваться с типами данных LOB или LONG.
Answer: A, B, D. Групповые функции AVG, SUM, VARIANCE и STDDEV могут использоваться только с числовыми данными. Ни одна из групповых функций не может использоваться с типом данных LONG.
52. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Найдите ошибку в запросе ниже.
SELECT department_id , avg(salary ), count(hiredate)
FROM employees
GROUP BY department_id ;
- В одном запросе SELECT нельзя использовать несколько агрегатных функций.
- Предложение GROUP BY недействительно
- Функция COUNT не может использоваться со значениями DATE
- Нет ошибок, и он выполняется успешно
Answer: D.
53. Which of the following group function can be used with LOB data types?
- MAX
- MIN
- COUNT
- Ни один из этих
Answer: D. С типами данных LOB нельзя использовать агрегатную функцию.
54. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Предсказать результат двух запросов ниже
Query - 1
SELECT avg(comm)
FROM employees ;
Query - 2
SELECT avg(nvl(comm,0))
FROM employees ;
- Оба запроса дают одинаковый результат
- Query - 1 и Query - 2 дают разные результаты, потому что Query-1 рассматривает NULL значения COMM, а Query-2 заменяет NULL значения COMM на ноль.
- Запрос - 1 вызывает ошибку, поскольку COMM имеет значения NULL
- Запрос - 2 вызывает ошибку, поскольку NVL не может быть вложен в агрегатную функцию.
Answer: B. Функция AVG игнорирует значения NULL при вычислении среднего числовых данных. AVG (столбец) вычислит среднее значение только для ненулевых значений. Однако, если NVL используется для замены NULL нулем, будут учитываться все значения.
55. Choose the correct statements about the GROUP BY clause.
- Псевдоним столбца можно использовать в предложении GROUP BY.
- Столбец GROUP BY должен быть в предложении SELECT.
- Предложение GROUP BY должно появляться вместе с предложением HAVING в запросе SELECT.
- Предложение GROUP BY должно появиться после предложения WHERE в запросе SELECT.
Answer: D. Согласно последовательности обработки, предложение GROUP BY должно появиться после предложения WHERE в запросе SELECT.
56. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Предскажите результат запроса ниже
SELECT department_id ,avg(salary )
FROM employees
GROUP BY department_id , job
ORDER BY department_id ;
- Это вызывает ошибку, потому что список столбцов GROUP BY не совпадает со списком столбцов SELECT.
- Он работает успешно и дает среднюю зарплату по категории должностей в каждом отделе.
- Он работает успешно и дает среднюю зарплату для отдела в каждой категории должностей.
- Это вызывает ошибку, потому что предложения GROUP BY и ORDER BY имеют разные списки столбцов.
Answer: B. Хотя предложение GROUP BY неявно сортирует группы, предложения GROUP BY и ORDER BY могут использоваться вместе в запросе.
57. Which clause should you use to exclude group results in a query using group functions?
- WHERE
- HAVING
- ГРУППА ПО
- СОРТИРОВАТЬ ПО
Answer: B. Предложение HAVING используется для ограничения групп.
Examine the table structure as given and answer the questions 58 and 59 that follow.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
58. Predict the outcome of the below query
SELECT department_id ,avg(salary )
FROM employees
HAVING avg(salary )>2000
GROUP BY department_id
ORDER BY department_id
- Он успешно выполняется.
- Это вызывает ошибку, потому что предложение HAVING предшествует предложению GROUP BY.
- Это вызывает ошибку, потому что предложение HAVING использует агрегатную функцию.
- Он выполняется, но результаты не отображаются, поскольку предложение HAVING предшествует предложению GROUP BY.
Answer: A. Предложение HAVING может предшествовать предложению GROUP BY, но оно обрабатывается только после вычисления результатов группы.
59. Predict the outcome of the below query
SELECT department_id , COUNT(first_name )
FROM employees
WHERE job IN ('SALESMAN','CLERK','MANAGER','ANALYST')
GROUP BY department_id
HAVING AVG(salary ) BETWEEN 2000 AND 3000;
- Он возвращает ошибку, поскольку оператор BETWEEN нельзя использовать в предложении HAVING.
- Он возвращает ошибку, потому что предложения WHERE и HAVING нельзя использовать в одном и том же операторе SELECT.
- Он возвращает ошибку, поскольку предложения WHERE и HAVING нельзя использовать для применения условий к одному и тому же столбцу.
- Он успешно выполняется.
Answer: D. Предложение WHERE ограничивает количество строк, участвующих в обработке предложения группы.
60. Which statements are true regarding the WHERE and HAVING clauses in a SELECT statement?
- Предложение HAVING можно использовать с групповыми функциями в подзапросах.
- Предложение WHERE можно использовать для исключения строк после их разделения на группы.
- Предложение WHERE можно использовать для исключения строк перед их разделением на группы.
- Предложения WHERE и HAVING можно использовать в одном операторе, только если они применяются к разным столбцам в таблице.
Answer: A, C. Предложение WHERE и HAVING можно использовать вместе в запросе. WHERE исключает строки перед групповой обработкой, в то время как HAVING ограничивает группы.
Examine the table structure as given and answer the questions 61 and 62 that follow.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
61. Predict the outcome of the below query.
SELECT department_id , avg(salary )
FROM employees
HAVING avg(salary ) > min(salary )
GROUP BY department_id ;
- Это вызывает ошибку, потому что агрегатные функции, используемые в предложении HAVING, должны быть в списке SELECT.
- Это вызывает ошибку, потому что предложение HAVING стоит перед предложением GROUP BY.
- В нем отображаются отделы, средняя заработная плата которых превышает минимальную заработную плату отдела.
- В нем отображаются отделы, средняя заработная плата которых больше минимальной заработной платы организации.
Answer: C. Групповые функции можно использовать с помощью предложения HAVING для фильтрации групп.
62. Interpret the output of the below query.
SELECT SUM(AVG(LENGTH(first_name )))
FROM employees
GROUP BY department_id ;
- Он вычисляет сумму средних значений длины имени сотрудника в каждом отделе.
- Он вычисляет среднюю длину имени сотрудника в каждом отделе.
- Это вызывает ошибку, потому что функция одной строки не может использоваться с групповыми функциями.
- Это вызывает ошибку, потому что столбец группы DEPARTMENT_ID не используется в списке SELECT.
Answer: A. Групповые функции могут использоваться с одной строкой или общими функциями в запросе SELECT.
63. Up to how many levels, the group functions can be nested?
- 1
- 2
- 3
- Без ограничений
Answer: B. Групповые функции могут быть вложены максимум до 2 уровней. Однако однострочные функции могут быть вложены до любого количества уровней.
64. What is the limit of number of groups within the groups created by GROUP BY clause?
- 1
- 2
- 3
- Нет ограничений
Answer: D. Количество групп и подгрупп, которые можно сформировать, не ограничено.
65. Choose the correct statements about the HAVING clause.
- Предложение HAVING - это необязательное предложение в операторе SELECT.
- Предложение HAVING является обязательным, если оператор SELECT использует предложение GROUP BY.
- Предложение HAVING может появиться в операторе SELECT, только если оно использует предложение GROUP BY.
- Предложение HAVING является обязательным, если оператор SELECT использует предложение GROUP BY.
Answer: A, C. Предложение HAVING может появиться в запросе, только если присутствует предложение GROUP BY, но наоборот неверно.
66. What is the output of the below query.
SELECT count(*) FROM dual GROUP BY dummy;
- 1
- 0
- NULL
- Выдает ошибку, потому что групповые функции не могут применяться к таблице DUAL.
Answer: A. Таблица DUAL содержит единственный столбец DUMMY типа CHAR (1), значение которого равно 'X'.
Based on the below scenario, answer the question from 67 to 74.
В организации 14 сотрудников, которые работают с фиксированной заработной платой из 1000 человек. Компания принимает на работу 5 новых сотрудников, зарплата которых еще не установлена отделом заработной платы. Однако во время обработки на конец месяца отдел расчета заработной платы HR создает несколько отчетов для согласования финансовых данных организации. Изучите структуру таблицы, как указано.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
67. What is the output of the below query?
SELECT SUM (salary ) FROM employees ;
- NULL
- 14000
- 19000
- 0
Answer: B. Функция СУММ складывает зарплаты сотрудников.
68. What is the output of the below query?
SELECT AVG (salary ) FROM employees ;
- 1000
- 736.84
- NULL
- 0
Answer: A. Функция AVG (зарплата) вычисляет среднее значение зарплаты, игнорируя значения NULL. В этом случае AVG (зарплата) = (14 * 1000) / 14 = 1000.
69. What is the output of the below query?
SELECT AVG (nvl(salary ,0)) FROM employees ;
- 1000
- NULL
- 736.84
- 0
Answer: C. AVG (NVL (salary, 0)) дает альтернативное значение NULL и позволяет им участвовать в вычислении среднего значения. В этом случае (14 * 1000) / 19 = 736,84.
70. What is the output of the below query?
SELECT VARIANCE (salary ) FROM employees ;
- 1000
- 0
- NULL
- 204678.36
Answer: B. VARIANCE (salary) вычисляет дисперсию значений столбца salary, игнорируя NULL.
71. What is the output of the below query?
SELECT VARIANCE (nvl(salary ,0)) FROM employees ;
- 1000
- 0
- NULL
- 204678.36
Answer: D. VARIANCE (NL (salary, 0)) вычисляет дисперсию значений столбца salary, включая NULL.
72. What is the output of the below query?
SELECT STDDEV (salary ) FROM employees ;
- 1
- 1000
- 0
- NULL
Answer: C. STDDEV (зарплата) вычисляет стандартное отклонение значений столбца зарплаты, игнорируя NULL.
73. What is the output of the below query?
SELECT STDDEV (nvl(salary ,0)) FROM employees ;
- 0
- 452.41
- 1000
- NULL
Answer: B. STDDEV (nvl (salary, 0)) вычисляет стандартное отклонение значений столбца salary, включая NULL.
74. What is the output of the below query?
- 19,19
- 14,19
- 19,14
- 14,14
Answer: C. COUNT (*) включает NULL, а COUNT (salary) игнорирует значения NULL.
75. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Какой из нижеприведенных запросов даст отдел, в котором работает более 5 сотрудников?
SELECT department_id FROM employees WHERE COUNT(*) > 5 GROUP BY department_id ;
SELECT department_id FROM employees HAVING COUNT(*) > 5;
SELECT department_id FROM employees GROUP BY employee_id HAVING COUNT(*) > 5;
SELECT department_id FROM employees GROUP BY department_id HAVING COUNT(*) > 5;
Answer: D.
76. Which of the following are true about the CUBE extension of GROUP BY?
- Позволяет выполнять несколько предложений GROUP BY с помощью одного запроса.
- Выполняет агрегирование для всех возможных комбинаций включенных столбцов.
- Выполняет возрастающие уровни кумулятивных промежуточных итогов на основе предоставленного списка столбцов.
- Ни один из вышеперечисленных
Answer: B. CUBE, ROLLUP - это расширения GROUP BY, используемые для обработки OLAP. CUBE объединяет результаты всякий раз, когда формируется новая перестановка столбца.
Use the following SELECT statement to answer below questions 77 to 82:
1 SELECT customer#, COUNT(*)
2 FROM customers JOIN orders USING (customer#)
3 WHERE orderdate > '02-APR-09'
4 GROUP BY customer#
5 HAVING COUNT(*) > 2;
77. Which line of the SELECT statement is used to restrict the number of records the query processes?
- 1
- 3
- 4
- 5
Answer: B. Предложение WHERE используется для ограничения строк до формирования групп.
78. Which line of the SELECT statement is used to restrict groups displayed in the query results?
- 1
- 3
- 4
- 5
Answer: D. HAVING используется для ограничения результатов группы после завершения групповой обработки.
79. Which line of the SELECT statement is used to group data stored in the database?
- 1
- 3
- 4
- 5
Answer: C. Предложение GROUP BY использует группировку по столбцам для группировки данных в таблице.
80. Which clause must be included for the query to execute successfully?
- 1
- 3
- 4
- 5
Answer: C. Поскольку предложение SELECT содержит столбец CUSTOMER #, обязательно наличие предложения GROUP BY со столбцом CUSTOMER #.
81. What is the purpose of using COUNT(*) in the SELECT query?
- Количество записей в указанных таблицах
- Количество заказов, размещенных каждым покупателем
- Количество значений NULL в указанных таблицах
- Количество клиентов, разместивших заказ
Answer: B. Он подсчитывает количество строк, обрабатываемых в группе. В этом случае группа формируется покупателем, и COUNT (*) учитывает заказы, размещенные каждым покупателем.
82. Which of the following functions can be used to determine the earliest ship date for all orders recently processed by JustLee Books?
- Функция СЧЁТ
- Функция МАКС
- МИН функция
- STDDEV функция
Answer: C. Функция MIN используется для получения наименьшего значения столбца. При использовании со столбцами даты он выбирает минимальную дату из столбца.
83. Which of the following is not a valid SELECT statement?
SELECT STDDEV(retail) FROM books;
SELECT AVG(SUM(retail)) FROM orders NATURAL JOIN orderitems NATURAL JOIN books GROUP BY customer#;
SELECT order#, TO_CHAR(SUM(retail),'999.99') FROM orderitems JOIN books USING (isbn) GROUP BY order#;
SELECT title, VARIANCE(retail-cost) FROM books GROUP BY pubid;
Answer: D. Предложение GROUP BY должно указывать столбец или набор столбцов, содержащихся в предложении SELECT. Здесь PUBID не содержится в предложении SELECT, следовательно, запрос недействителен.
84. Which of the below statements are true about the nesting of group functions?
- Самая внутренняя функция решается первой.
- Oracle допускает вложение групповых функций до 3-х уровней.
- Однострочные функции могут быть вложены в групповые функции.
- Oracle допускает вложение групповых функций до 2 уровней.
Answer: A, C, D. В выражении, содержащем вложенные функции, самая внутренняя функция выполняется первой, результат которой передается в следующую функцию, движущуюся наружу. Однорядные функции могут быть хорошо использованы с групповыми функциями, которые могут иметь максимум 2 уровня вложенности.
85. What are the statistical group functions in Oracle?
- AVG
- STDDEV
- VARIANCE
- STATS
Answer: B, C. VARIANCE и STATS - это функции статистической группы, доступные в Oracle SQL.
86. If the SELECT list contains a column and a group functions, which of the following clause must be mandatorily included?
- СОРТИРОВАТЬ ПО
- HAVING
- ГРУППА ПО
- Ни один из этих
Answer: C. Предложение GROUP BY обязательно должно содержать столбец или набор столбцов, содержащихся в предложении SELECT.
87. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Как лучше всего объяснить, почему этот оператор SQL НЕ будет выполняться?
SELECT department_id "Department", AVG (salary)"Average"
FROM employees
GROUP BY Department;
- Зарплаты не могут быть усреднены, так как не все числа делятся равномерно.
- Вы не можете использовать псевдоним столбца в предложении GROUP BY.
- В предложении GROUP BY должно быть что-то для GROUP.
- Идентификатор отдела не указан в таблице отделов.
Answer: B. Ни предложение GROUP BY, ни предложение HAVING не работают с псевдонимом столбца.
88. Which of the following data types are compatible with AVG, SUM, VARIANCE, and STDDEV functions?
- Только числовые типы данных
- Только целые числа
- Любой тип данных
- Все кроме числовых
Answer: A. Функции AVG, SUM, VARIANCE и STDDEV обязательно работают только с числовым типом данных.
Examine the table structure as given below and answer the questions 89 and 90 that follow.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
89. Which of the below query will display the number of distinct job categories working in each department?
SELECT department_id , COUNT(DISTINCT job) FROM employees GROUP BY job;
SELECT department_id , COUNT(job) FROM employees GROUP BY employee_id ;
SELECT department_id , COUNT(job) FROM employees GROUP BY department_id ;
SELECT department_id , COUNT(DISTINCT job) FROM employees GROUP BY department_id ;
Answer: D. Используйте модификатор DISTINCT, чтобы отфильтровать дубликаты.
90. Evaluate this SQL statement:
SELECT employee_id , first_name , department_id , SUM(salary )
FROM employees
WHERE salary > 1000
GROUP BY department_id , employee_id , first_name
ORDER BY hiredate;
Почему это утверждение вызовет ошибку?
- Предложение HAVING отсутствует.
- Предложение WHERE содержит синтаксическую ошибку.
- Столбец SALARY НЕ включен в предложение GROUP BY.
- Столбец HIRE_DATE НЕ включен в предложение GROUP BY.
Answer: D. Все столбцы, появляющиеся в предложениях SELECT и ORDER BY, должны быть включены в предложение GROUP BY.
91. Which of the following statements is true about the GROUP BY clause?
- Чтобы исключить строки перед их разделением на группы с помощью предложения GROUP BY, используйте предложение WHERE.
- Вы должны использовать предложение HAVING с предложением GROUP BY.
- Псевдоним столбца можно использовать в предложении GROUP BY.
- По умолчанию при использовании предложения GROUP BY строки не сортируются.
Answer: A. Используя предложение WHERE, вы можете исключить строки, прежде чем разделить их на группы.
92. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Интерпретируйте результат запроса ниже.
SELECT department_id , MIN (hiredate)
FROM employees
GROUP by department_id ;
- Самая ранняя дата приема на работу в организации.
- Последняя дата приема на работу в организации.
- Самая ранняя дата приема на работу в отдел.
- Последняя дата приема на работу в отдел.
Answer: C. Запрос возвращает самого раннего нанятого сотрудника в каждом отделе.
93. Which statement about group functions is true?
- Групповые функции, кроме COUNT (*), игнорируют нулевые значения.
- Запрос, который включает групповую функцию в список SELECT, должен включать предложение GROUP BY.
- Групповые функции можно использовать в предложении WHERE.
- Групповые функции можно использовать только в списке SELECT.
Answer: A. Все групповые функции, кроме COUNT (*), игнорируют значения NULL. Это потому, что они обрабатывают значения, непосредственно содержащиеся в определенном столбце.
94. Which of the following clauses represent valid uses of group functions?
- ГРУППА ПО МАКСУ (зарплата)
- ЗАКАЗ ПО СРЕДНЕМУ (зарплата)
- ИМЕЕТ МАКС (зарплата)> 10000
- ВЫБРАТЬ СРЕДНЕЕ (NVL (зарплата, 0))
Answer: B, C, D. Групповые функции могут появляться только в предложениях SELECT, HAVING и ORDER BY.
95. Which of the following statements are true about the GROUP BY clause?
- Последний столбец, указанный в предложении GROUP BY, является наиболее важной группировкой.
- Первый столбец, указанный в предложении GROUP BY, представляет собой наиболее важную группировку.
- Предложение GROUP BY не может использоваться без предложения ORDER BY.
- Предложение GROUP BY не обеспечивает сортировку вывода.
Answer: B. Группировка данных основана на последовательности столбцов, указанных в предложении GROUP BY.
96. What is difference between WHERE clause and HAVING clause?
- Предложение WHERE ограничивает строки перед группировкой, а предложение HAVING ограничивает группы.
- Предложение WHERE не может содержать групповую функцию, но предложение HAVING может содержать.
- Предложение WHERE может объединять несколько условий с помощью операторов AND или OR, а предложение HAVING - нет.
- Предложение WHERE может появляться в запросе SELECT без предложения GROUP BY, но предложение HAVING не может.
Answer: A, B, D. Предложение WHERE ограничивает строки перед группировкой, но HAVING ограничивает группы.
97. Examine the table structure as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Предскажите результат запроса ниже.
SELECT department_id ,job,count(*)
FROM employees
GROUP BY department_id ,job
ORDER BY department_id ,count(*);
- Он успешно выполняется.
- Выдает ошибку, потому что предложение ORDER BY недействительно.
- Это вызывает ошибку, потому что предложение GROUP BY недействительно.
- Это вызывает ошибку, потому что предложения GROUP BY и ORDER BY не могут использоваться вместе.
Answer: A. Предложение ORDER BY может использовать групповые функции для сортировки.