Korzystanie z pytań dotyczących funkcji grupowych

1. Which of the following is NOT a GROUP BY function?

  1. MAX
  2. MIN
  3. NVL
  4. AVG

Answer: C. NVL to ogólna funkcja używana do dostarczania alternatywnej wartości wartości NULL. Funkcje MAX, MIN i AVG mogą być używane jako funkcje GROUP BY.

2. Which of the following functions can be used without GROUP BY clause in SELECT query?

  1. COUNT
  2. MAX
  3. MIN
  4. AVG

Answer: A, B, C, D. Wszystkie wymienione funkcje grup mogą być używane w zapytaniu, pod warunkiem, że w zapytaniu SELECT nie wybrano żadnych innych kolumn.

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)
  1. SELECT department_id , max(salary ) FROM employees ;
  2. SELECT department_id , max(salary ) FROM employees  GROUP BY department_id ;
  3. SELECT max(salary ) FROM employees  GROUP BY department_id ;
  4. SELECT max(salary ) FROM employees ;

Answer: B. Funkcja MAX może służyć do zwracania maksymalnego wynagrodzenia w dziale, w którym każda grupa jest utworzona przez dział.

4. Which of the following statements are true about the COUNT function?

  1. Funkcja COUNT zlicza wiersze
  2. Funkcja COUNT (*) zlicza wiersze z duplikatami i wartościami NULL
  3. Funkcja COUNT (DISTINCT) zlicza liczbę różnych wierszy
  4. COUNT (*) jest równoważne z COUNT (ALL)

Answer: B. COUNT (*) zlicza wiersze, w tym duplikaty i wartości NULL. Użyj słów kluczowych DISTINCT i ALL, aby ograniczyć zduplikowane i NULL wartości.

5. What are the appropriate data types accepted by GROUP BY functions?

  1. Tabele zagnieżdżone
  2. NUMBER
  3. CLOB
  4. DATE

Answer: B. Typami danych dla funkcji z argumentem mogą być CHAR, VARCHAR2, NUMBER lub 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;
  1. 12
  2. 6
  3. 9
  4. Zgłasza wyjątek, ponieważ funkcja COUNT nie działa z wartościami NULL

Answer: A. COUNT (*) zlicza wiersze, w tym duplikaty i wartości NULL. Użyj słów kluczowych DISTINCT i ALL, aby ograniczyć zduplikowane i NULL wartości.

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;
  1. 12
  2. 6
  3. 9
  4. Zgłasza wyjątek, ponieważ funkcja COUNT nie działa z wartościami NULL

Answer: C. COUNT (kolumna) ignoruje wartości NULL, ale zlicza duplikaty.

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;
  1. 12
  2. 6
  3. 9
  4. Zgłasza wyjątek, ponieważ funkcja COUNT nie działa z wartościami NULL

Answer: C. COUNT (kolumna ALL) ignoruje wartości NULL, ale zlicza duplikaty.

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;
  1. 12
  2. 6
  3. 9
  4. Zgłasza wyjątek, ponieważ funkcja COUNT nie działa z wartościami NULL

Answer: B. COUNT (kolumna DISTINCT) zlicza różne wartości inne niż null.

10. What happens when the below query is executed in SQL* Plus?

SELECT COUNT() FROM dual;
  1. Wykonuje się pomyślnie i nie zwraca żadnego wyniku
  2. Wykonuje się pomyślnie i zwraca wynik jako „1”
  3. Zgłasza wyjątek „ORA-00909: nieprawidłowa liczba argumentów”
  4. Zgłasza wyjątek „ORA-00904:„ COUNT ”: nieprawidłowy identyfikator”, ponieważ funkcja COUNT nie działa z tabelą DUAL

Answer: C. Funkcja COUNT wymaga co najmniej jednego argumentu, którym może być kolumna z [WSZYSTKIE | DISTINCT] lub „*”.

11. Here are few statements about VARIANCE function in SQL.

ja. Funkcja akceptuje wiele liczbowych danych wejściowych i zwraca wariancję wszystkich wartości

ii. Funkcja akceptuje kolumnę liczbową i zwraca wariancję wszystkich wartości kolumn, w tym wartości NULL

iii. Funkcja akceptuje kolumnę liczbową i zwraca wariancję wartości wszystkich kolumn z wyłączeniem wartości NULL

Wybierz odpowiednią kombinację z poniższych opcji.

  1. i i iii
  2. i i ii
  3. ii
  4. iii

Answer: C. Funkcja VARIANCE przyjmuje pojedynczy argument liczbowy jako nazwę kolumny i zwraca wariancję wszystkich wartości kolumn uwzględniających wartości NULL.

12. Which of the following is NOT a GROUP BY extensions in SQL?

  1. GRUPUJ WEDŁUG
  2. ZESTAWY GRUPOWANE
  3. CUBE
  4. ROLLUP

Answer: A. Operacje GROUPING SETS mogą służyć do wykonywania wielu agregacji GROUP BY za pomocą jednego zapytania.

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 ;
  1. SUMA to grupa według funkcji, ponieważ przetwarza grupę pracowników pracujących w dziale
  2. SUMA jest funkcją agregującą, ponieważ generuje jeden wynik na grupę danych
  3. SUMA to funkcja pojedynczego wiersza, ponieważ zwraca pojedynczą wartość dla grupy, tj. Działu
  4. SUMA jest funkcją grupowania według rozszerzenia, ponieważ używa klauzuli GROUP BY do logicznego grupowania działów

Answer: A. SUMA to funkcja grupowa, która oblicza sumę wynagrodzeń grupy pracowników działu.

14. Which clause is used to filter the query output based on aggregated results using a group by function?

  1. WHERE
  2. LIMIT
  3. GRUPA GDZIE
  4. HAVING

Answer: D. Klauzula HAVING służy do ograniczania wyników grupowych. Klauzula HAVING służy do określania grup, które mają być wyświetlane, a tym samym dalszego ograniczania grup na podstawie informacji zbiorczych. Klauzula HAVING może poprzedzać klauzulę GROUP BY, ale zaleca się umieszczenie klauzuli GROUP BY jako pierwszej, ponieważ jest ona bardziej logiczna. Grupy są tworzone, a funkcje grupowe obliczane przed zastosowaniem klauzuli HAVING do grup na liście 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;
  1. Zapytanie zwraca liczbę pracowników, którzy nie mają prowizji
  2. Zapytanie generuje błąd, ponieważ nie można użyć znaku równości podczas wyszukiwania wartości NULL
  3. Zapytanie zwraca liczbę pracowników w dziale, którego prowizja ma wartość NULL
  4. Zapytanie zgłasza błąd, ponieważ w zapytaniu brakuje klauzuli GROUP BY

Answer: B. Wykluczenie wartości NULL przy użyciu warunku WHERE jest sposobem skierowania zapytania w celu zignorowania wartości NULL. Ale tutaj użycie operatora IS NULL jest błędne. Warunkiem powinno być „WHERE comm IS NULL”.

16. Which of the following statements is true about the group functions?

  1. Funkcja MIN może być używana tylko z danymi liczbowymi.
  2. Funkcja MAX może być używana tylko z wartościami dat.
  3. Funkcji AVG można używać tylko z danymi liczbowymi.
  4. Funkcja SUMA nie może być częścią funkcji zagnieżdżonej.

Answer: C. Funkcji AVG można używać tylko z wartościami liczbowymi. Inne funkcje, które mają takie ograniczenie, to SUMA, STDDEV i VARIANCE.

17. Which of the following is a valid SELECT statement?

  1. SELECT AVG(retail-cost) FROM books GROUP BY category;
  2. SELECT category, AVG(retail-cost) FROM books;
  3. SELECT category, AVG(retail-cost) FROM books WHERE AVG(retail-cost) > 8.56 GROUP BY category;
  4. SELECT category, AVG(retail-cost) Profit FROM books GROUP BY category HAVING profit > 8.56;

Answer: A. Aliasy kolumn nie mogą być używane w klauzuli GROUP BY ani HAVING.

18. Which of the following statements is correct?

  1. Klauzula WHERE może zawierać funkcję grupy tylko wtedy, gdy funkcja nie jest również wymieniona w klauzuli SELECT.
  2. Funkcji grupowych nie można używać w klauzulach SELECT, FROM ani WHERE.
  3. Klauzula HAVING jest zawsze przetwarzana przed klauzulą ​​WHERE.
  4. Klauzula GROUP BY jest zawsze przetwarzana przed klauzulą ​​HAVING.

Answer: D. Chociaż Oracle nie zgłasza błędu, jeśli klauzula HAVING poprzedza klauzulę GROUP BY, ale jest przetwarzana dopiero po przetworzeniu klauzuli GROUP BY, a grupa jest gotowa do filtrowania.

19. Which of the following is not a valid SQL statement?

  1. SELECT MIN(pubdate) FROM books GROUP BY category HAVING pubid = 4;
  2. SELECT MIN(pubdate) FROM books WHERE category = 'COOKING';
  3. SELECT COUNT(*) FROM orders WHERE customer# = 1005;
  4. SELECT MAX(COUNT(customer#)) FROM orders GROUP BY customer#;

Answer: A.

20. Which of the following statements is correct?

  1. Funkcja COUNT może służyć do określenia, ile wierszy zawiera wartość NULL.
  2. W funkcjach grupowych uwzględniane są tylko odrębne wartości, chyba że słowo kluczowe ALL jest zawarte w klauzuli SELECT.
  3. Klauzula WHERE ogranicza przetwarzane wiersze.
  4. Klauzula HAVING określa, które grupy są wyświetlane w wynikach zapytania.

Answer: C, D. Klauzula WHERE ogranicza wiersze przed ich grupowaniem i przetwarzaniem, a klauzula HAVING ogranicza grupy.

21. Which of the following is a valid SQL statement?

  1. SELECT customer#, order#, MAX(shipdate-orderdate) FROM orders GROUP BY customer# WHERE customer# = 1001;
  2. SELECT customer#, COUNT(order#) FROM orders GROUP BY customer#;
  3. SELECT customer#, COUNT(order#) FROM orders GROUP BY COUNT(order#);
  4. SELECT customer#, COUNT(order#) FROM orders GROUP BY order#;

Answer: B. Klauzula GROUP BY musi zawierać wszystkie kolumny z wyjątkiem tej, która jest używana wewnątrz funkcji grupy.

22. Which of the following SELECT statements lists only the book with the largest profit?

  1. SELECT title, MAX(retail-cost) FROM books GROUP BY title;
  2. SELECT title, MAX(retail-cost) FROM books GROUP BY title HAVING MAX(retail-cost);
  3. SELECT title, MAX(retail-cost) FROM books;
  4. Żadne z powyższych

Answer: A.

23. Which of the following statement(s) is/are correct?

1. Funkcja grupowa może być zagnieżdżona wewnątrz funkcji grupowej.

2. Funkcja grupowa może być zagnieżdżona wewnątrz funkcji jednorzędowej.

3. Funkcja jednorzędowa może być zagnieżdżona wewnątrz funkcji grupowej.

  1. 1
  2. 2
  3. 3
  4. 1 i 3

Answer: A, B, C. Funkcje grupowe można zagnieżdżać tylko do głębokości dwóch. Funkcje grupowe można zagnieżdżać w funkcjach jednorzędowych (AVG osadzony w funkcji TO_CHAR). Ponadto funkcje jednorzędowe można zagnieżdżać w funkcjach grupowych.

24. Which of the following functions is used to calculate the total value stored in a specified column?

  1. COUNT
  2. ADD
  3. TOTAL
  4. SUM

Answer: D. Funkcja SUMA służy do dodawania wartości liczbowych.

25. Which of the following SELECT statements lists the highest retail price of all books in the Family category?

  1. SELECT MAX(retail) FROM books WHERE category = 'FAMILY';
  2. SELECT MAX(retail) FROM books HAVING category = 'FAMILY';
  3. SELECT retail FROM books WHERE category = 'FAMILY' HAVING MAX(retail);
  4. Żadne z powyższych

Answer: A. Ponieważ kategoria FAMILY musi zostać ograniczona przed grupowaniem, wiersze tabeli należy filtrować za pomocą klauzuli WHERE, a nie klauzuli HAVING.

26. Which of the following functions can be used to include NULL values in calculations?

  1. SUM
  2. NVL
  3. MAX
  4. MIN

Answer: B.NVL to ogólna funkcja zapewniająca alternatywne wartości wartości NULL. To naprawdę może mieć znaczenie w obliczeniach arytmetycznych z wykorzystaniem funkcji grupowych AVG, STDDEV i VARIANCE.

27. Which of the following is not a valid statement?

  1. Musisz wprowadzić słowo kluczowe ALL w funkcji grupy, aby uwzględnić wszystkie zduplikowane wartości.
  2. Funkcji AVG można użyć do znalezienia średniej obliczonej różnicy między dwiema datami.
  3. Funkcji MIN i MAX można używać w kolumnach VARCHAR2.
  4. Wszystkie powyższe

Answer: A. Słowo kluczowe ALL liczy duplikaty, ale ignoruje wartości NULL. Duplikaty są również uwzględniane ze znakiem „*” i specyfikacją nazwy kolumny.

28. Which of the following SQL statements determines how many total customers were referred by other customers?

  1. SELECT customer#, SUM(referred) FROM customers GROUP BY customer#;
  2. SELECT COUNT(referred) FROM customers;
  3. SELECT COUNT(*) FROM customers;
  4. SELECT COUNT(*) FROM customers WHERE referred IS NULL;

Answer: B. Traktując wszystkich klientów jako jedną grupę, LICZBA (poleconych) będzie liczyć tylko tych, których ktoś polecił. COUNT (odniesione) zignoruje wartości NULL kolumny.

29. Determine the correct order of execution of following clauses in a SELECT statement.

1.WYBIERZ

2. OD

3 GDZIE

4.GROUP BY

5. POSIADAJĄC

6. ZAMÓWIENIE

  1. 2-3-4-5-1-6
  2. 1-2-3-4-5-6
  3. 6-5-4-3-2-1
  4. 5-4-2-3-1-6

Answer: A. Kolejność przetwarzania zaczyna się od klauzuli FROM w celu pobrania nazw tabel, następnie ogranicza wiersze za pomocą klauzuli WHERE, grupuje je za pomocą klauzuli GROUP BY, ogranicza grupy za pomocą klauzuli HAVING. Klauzula ORDER BY jest ostatnią, która ma być przetwarzana w celu sortowania końcowego zestawu danych.

30. Which of the below clauses is used to group a set of rows based on a column or set of columns?

  1. HAVING
  2. WHERE
  3. GRUPUJ WEDŁUG
  4. GROUPING

Answer: C. Klauzula GROUP BY tworzy grupy danych na podstawie określonej listy kolumn.

31. Which of the following group functions can be used for population variance and population standard deviation problems?

  1. VAR_POP
  2. STDDEV_POP
  3. VARIANCE
  4. STDDEV_SASMP

Answer: A, B.

32. Select the positions in a SELECT query where a group function can appear.

  1. Instrukcja SELECT
  2. Klauzula WHERE
  3. Klauzula ORDER BY
  4. Klauzula GROUP BY

Answer: A, C, D. Funkcje grupowe mogą pojawiać się w klauzulach SELECT, ORDER BY i HAVING. Oracle zgłasza wyjątek, jeśli funkcje grupowe są używane w klauzulach WHERE lub 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)
  1. SELECT department_id , MIN (salary ) from EMPLOYEES ;
  2. SELECT department_id , MIN (salary ) from EMPLOYEES  GROUP BY department_id ;
  3. SELECT department_id , MIN (salary ) from EMPLOYEES  GROUP BY salary ;
  4. SELECT department_id , MIN (salary ) from EMPLOYEES  GROUP BY employee_id ;

Answer: B. Funkcja MIN zwraca minimalne wynagrodzenie w grupie utworzonej przez dział.

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 ;
  1. Zgłasza błąd, ponieważ w zapytaniu można użyć tylko jednej funkcji agregującej.
  2. Zgłasza błąd, ponieważ brakuje klauzuli GROUP BY.
  3. Wykonuje się pomyślnie i zwraca te same wartości dla obu.
  4. Wykonywany jest pomyślnie, gdzie COUNT (*), w tym wartości NULL i COUNT (all comm) z wyłączeniem NULL.

Answer: D.

35. Which of the following are true about group functions?

  1. Funkcji grup można używać w dowolnej klauzuli instrukcji SELECT.
  2. Funkcji grupowych można używać tylko na liście kolumn w klauzuli select oraz w klauzuli WHERE instrukcji SELECT.
  3. Na liście kolumn instrukcji SELECT można łączyć kolumny z jednym wierszem z funkcjami grupowymi, grupując je według kolumn z jednym wierszem.
  4. Nazwy kolumn, wyrażenia, stałe lub funkcje można przekazywać jako parametry do funkcji grupy.

Answer: C. Funkcje grupowe można zagnieżdżać tylko do głębokości dwóch. Funkcje grupowe można zagnieżdżać w funkcjach jednorzędowych (AVG osadzony w funkcji TO_CHAR). Ponadto funkcje jednorzędowe można zagnieżdżać w funkcjach grupowych.

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 ;

Które stwierdzenie jest prawdziwe w odniesieniu do wykonania powyższego oświadczenia?

  1. Widok zostanie utworzony i możesz na nim wykonywać operacje DLM
  2. Widok nie zostanie utworzony, ponieważ instrukcje łączenia nie umożliwiają tworzenia widoku
  3. Widok nie zostanie utworzony, ponieważ klauzula GROUP BY nie umożliwia tworzenia widoku
  4. Widok zostanie utworzony, ale żadne operacje DML nie będą dozwolone w widoku

Answer: D. Zasady wykonywania operacji DML na widoku. Nie można dodawać danych za pośrednictwem widoku, jeśli widok zawiera funkcje grupowe lub klauzulę GROUP BY lub słowo kluczowe DISTINCT. Pseudokolumna Słowo kluczowe ROWNUM Kolumny zdefiniowane przez wyrażenia NOT NULL kolumny w tabelach podstawowych, które nie są wybierane przez widok.

37. Which of the following statements are true regarding views?

  1. Zapytanie podrzędne, które definiuje widok, nie może zawierać klauzuli GROUP BY
  2. Widok jest tworzony za pomocą zapytania podrzędnego mającego słowo kluczowe DISTINCT, które można zaktualizować
  3. Operację języka manipulacji danymi (DML) można wykonać na widoku utworzonym za pomocą zapytania podrzędnego zawierającego wszystkie kolumny NOT NULL tabeli
  4. Widok utworzony za pomocą zapytania podrzędnego ze słowem kluczowym pseudokolumny ROWNUM nie może zostać zaktualizowany

Answer: C, D. Zasady wykonywania operacji DML na widoku. Nie można dodawać danych za pośrednictwem widoku, jeśli widok zawiera funkcje grupowe lub klauzulę GROUP BY lub słowo kluczowe DISTINCT. Pseudokolumna Słowo kluczowe ROWNUM Kolumny zdefiniowane przez wyrażenia NOT NULL kolumny w tabelach podstawowych, które nie są wybierane przez widok.

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)

Która klauzula w poniższym zapytaniu SQL generuje błąd?

SELECT department_id , avg(salary )
FROM departments 
WHERE upper(job) in ('SALES','CLERK')
GROUP BY job
ORDER BY department_id ;
  1. WHERE
  2. SELECT
  3. ZAMÓW PRZEZ
  4. GRUPUJ WEDŁUG

Answer: D. Klauzula GROUP BY musi zawierać wszystkie kolumny występujące w instrukcji SELECT. Powoduje to błąd, ponieważ JOB nie jest wybraną kolumną. Powinien był użyć DEPARTMENT_ID w miejscu 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)

Które z poniższych zapytań SELECT wyświetli maksymalną i minimalną pensję uzyskaną w każdej kategorii stanowisk?

  1. SELECT job, MAX(salary ), MIN (salary ) FROM employees  GROUP BY department_id ;
  2. SELECT job, MAX(salary ), MIN (salary ) FROM employees  GROUP BY job;
  3. SELECT job, MAX(salary ), MIN (salary ) FROM employees ;
  4. W instrukcji SELECT nie można używać razem dwóch funkcji agregujących.

Answer: B. W instrukcji SELECT może pojawić się więcej niż jedna funkcja grupowa.

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)

Sprawdź błąd w poniższym zapytaniu.

SELECT department_id 
FROM employees 
WHERE hiredate > '01-JAN-1985'
AND COUNT(*) > 2
GROUP by department_id 
HAVING SUM (salary ) > 1000;
  1. Wykonuje się pomyślnie i generuje wymagany wynik.
  2. Powoduje to błąd, ponieważ COUNT (*) powinno być również określone w klauzuli SELECT.
  3. Wykonuje się pomyślnie, ale nie daje żadnego wyniku, ponieważ zamiast COUNT (*) należy użyć COUNT (prod_id).
  4. Powoduje to błąd, ponieważ COUNT (*) powinno znajdować się tylko w klauzuli HAVING, a nie w klauzuli WHERE.

Answer: D. W klauzuli WHERE nie można używać funkcji grupowych. Może pojawić się w klauzulach SELECT, HAVING i 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)

Przewidzieć wynik poniższego zapytania

SELECT job, COUNT(employee_id ),sum(salary )
FROM employees 
GROUP BY job
HAVING SUM (salary ) > 5000;
  1. Wykonuje się pomyślnie i wyświetla liczbę pracowników w każdej kategorii stanowisk, ale ignoruje klauzulę HAVING, ponieważ „wynagrodzenie” nie znajduje się w klauzuli GROUP BY.
  2. Zgłasza błąd, ponieważ klauzula HAVING jest nieprawidłowa.
  3. Zgłasza błąd, ponieważ „wynagrodzenie” nie jest uwzględnione w klauzuli GROUP BY.
  4. Wykonuje pomyślnie i podaje liczbę pracowników w każdej kategorii o sumie wynagrodzeń powyżej 5000.

Answer: D. Klauzula HAVING ogranicza wyniki grupowe. Funkcja COUNT służy do liczenia, a SUMA służy do dodawania wartości liczbowych.

42. What is true of using group functions on columns that contain NULL values?

  1. Funkcje grupowe w kolumnach ignorują wartości NULL.
  2. Funkcje grupowe w kolumnach zwracających daty zawierają wartości NULL.
  3. Funkcje grupowe na kolumnach zwracających liczby zawierają wartości NULL.
  4. Funkcji grupowania w kolumnach nie można dokładnie używać w kolumnach zawierających wartości NULL.

Answer: A. Z wyjątkiem funkcji COUNT, wszystkie funkcje grupowe ignorują wartości NULL.

43. Which of the following statetments are true about the usage of GROUP BY columns in a subquery?

  1. Podzapytania mogą zawierać klauzule GROUP BY i ORDER BY.
  2. Podzapytania nie mogą zawierać klauzul GROUP BY i ORDER BY.
  3. Podkwerendy mogą zawierać klauzulę ORDER BY, ale nie klauzulę GROUP BY.
  4. Podkwerendy nie mogą zawierać ORDER BY, ale mogą zawierać klauzulę GROUP BY.

Answer: A. Podobnie jak zapytanie podstawowe, podzapytanie może zawierać klauzulę GROUP BY oraz 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;
  1. Wykonuje się pomyślnie.
  2. Daje błąd, ponieważ klauzula HAVING jest nieprawidłowa.
  3. Daje błąd, ponieważ wyrażenie GROUP BY jest nieprawidłowe.
  4. Daje błąd, ponieważ funkcje agregujące nie mogą być zagnieżdżone w instrukcji SELECT.

Answer: B. Klauzula HAVING nie pozwala na zagnieżdżanie funkcji agregujących.

45. Predict the output of the below query

SELECT avg(salary ), department_id 
FROM employees 
GROUP BY department_id ;
  1. Daje błąd, ponieważ funkcja agregująca nie może pojawić się tuż po klauzuli SELECT.
  2. Daje błąd, ponieważ klauzula GROUP BY jest nieprawidłowa.
  3. Wykonuje się bez błędów, ale nie generuje żadnych danych wyjściowych.
  4. Wykonuje z powodzeniem i daje średnie wynagrodzenie w każdym dziale.

Answer: D. Funkcje grupowe mogą być używane w dowolnej kolejności (przed lub po grupowaniu według kolumn) w zapytaniu SELECT.

46. Predict the output of the below query

SELECT lower(job),avg(salary )
FROM employees 
GROUP BY upper(job);
  1. Wykonuje się pomyślnie i wyświetla „zadanie” małymi literami.
  2. Wykonuje się pomyślnie, ale wyświetla „zadanie” w oryginalnym przypadku.
  3. Zgłasza błąd, ponieważ funkcji pojedynczego wiersza i agregacji nie można używać razem.
  4. Zgłasza błąd, ponieważ konwersja wielkości liter na liście SELECT jest niezgodna z klauzulą ​​GROUP BY konwersji wielkości liter.

Answer: D. Funkcja LOWER, będąca funkcją pojedynczego wiersza, musi być określona w klauzuli GROUP BY, aby oprzeć grupowanie danych EMPLOYEES.

47. Which of the below query executes successfully?

  1. SELECT employee_id , COUNT(hiredate-sysdate) FROM employees ;
  2. SELECT AVG(salary ), MAX(salary ) FROM employees ;
  3. SELECT AVG(salary ), MAX(salary ) FROM employees  GROUP BY department_id ;
  4. SELECT AVG(hiredate) FROM employees ;

Answer: B, C. Pierwsze zapytanie działa na całych danych PRACOWNIKÓW, podczas gdy drugie przetwarza dane w grupach działów.

48. Identify the error in the below SELECT statement.

SELECT department_id , AVG (salary )
FROM employees 
GROUP BY department_id 
HAVING department_id  > 10;
  1. Wykonuje pomyślnie i wyświetla średnie wynagrodzenie działów powyżej 10.
  2. Zgłasza błąd, ponieważ w klauzuli HAVING nie można użyć niezagregowanej kolumny.
  3. Wykonuje się pomyślnie, ale wyświetla nieprawidłowy wynik dla działów.
  4. Zgłasza błąd, ponieważ klauzula HAVING musi być umieszczona przed klauzulą ​​GROUP BY.

Answer: A. Wyrażenia GROUP BY mogą być używane w klauzuli HAVING w celu odfiltrowania grup z końcowego zestawu danych.

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);
  1. Zgłasza błąd, ponieważ w klauzuli HAVING nie można podać wielu warunków.
  2. Zgłasza błąd, ponieważ w klauzuli HAVING nie można użyć kolumny niezagregowanej.
  3. Wykonuje pomyślnie i wyświetla średnie wynagrodzenie działu powyżej 10 i powyżej 2000.
  4. Wykonuje się pomyślnie, ale nie jest wyświetlany wynik.

Answer: C. Klauzula HAVING może narzucić wiele warunków połączonych za pomocą operatora AND lub OR filtrującego grupy.

50. Which of the following group functions can be used with DATE values?

  1. AVG
  2. MIN
  3. SUM
  4. COUNT

Answer: B, D. Funkcji grupowych ŚREDNIA i SUMA można używać tylko w przypadku danych liczbowych.

51. Which of the following statements are true?

  1. AVG i SUM mogą być używane tylko z liczbowymi typami danych.
  2. STDDEV i VARIANCE mogą być używane tylko z numerycznymi typami danych.
  3. MAX może być używany z typem danych LONG.
  4. MAX i MIN nie mogą być używane z typami danych LOB lub LONG.

Answer: A, B, D. Funkcje grupowe ŚREDNIA, SUMA, ODCHYL. STANDARDOWE i ŚREDNIA mogą być używane tylko z danymi liczbowymi. Żadna z funkcji grupowych nie może być używana z typem danych 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)

Zidentyfikuj błąd w poniższym zapytaniu.

SELECT department_id , avg(salary ), count(hiredate)
FROM employees 
GROUP BY department_id ;
  1. W jednym zapytaniu SELECT nie można używać wielu funkcji agregujących
  2. Klauzula GROUP BY jest nieprawidłowa
  3. Funkcja LICZBA nie może być używana z wartościami DATA
  4. Brak błędów i działa pomyślnie

Answer: D.

53. Which of the following group function can be used with LOB data types?

  1. MAX
  2. MIN
  3. COUNT
  4. Żaden z tych

Answer: D. Żadna funkcja agregująca nie może być używana z typami danych 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)

Przewiduj wynik poniższych dwóch zapytań

Query - 1

SELECT avg(comm)
FROM employees ;

Query - 2

SELECT avg(nvl(comm,0))
FROM employees ;
  1. Oba zapytania dają ten sam wynik
  2. Zapytania - 1 i Zapytanie - 2 dają różne wyniki, ponieważ Query-1 bierze pod uwagę NULL wartości COMM, a Query-2 zastępuje NULL wartości COMM przez zero
  3. Zapytanie - 1 powoduje błąd, ponieważ COMM ma wartości NULL
  4. Zapytanie - 2 powoduje błąd, ponieważ NVL nie może być zagnieżdżony z funkcją agregującą.

Answer: B. Funkcja AVG ignoruje wartości NULL podczas obliczania średniej danych liczbowych. AVG (kolumna) obliczy średnią tylko dla wartości innych niż null. Jeśli jednak NVL zostanie użyty do zastąpienia wartości NULL zerem, wszystkie wartości zostaną uwzględnione.

55. Choose the correct statements about the GROUP BY clause.

  1. Alias ​​kolumny może być używany w klauzuli GROUP BY.
  2. Kolumna GROUP BY musi znajdować się w klauzuli SELECT.
  3. Klauzula GROUP BY musi występować razem z klauzulą ​​HAVING w zapytaniu SELECT.
  4. Klauzula GROUP BY musi występować po klauzuli WHERE w zapytaniu SELECT.

Answer: D. Zgodnie z sekwencją przetwarzania klauzula GROUP BY musi występować po klauzuli WHERE w zapytaniu 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)

Przewidzieć wynik poniższego zapytania

SELECT department_id ,avg(salary )
FROM employees 
GROUP BY department_id , job
ORDER BY department_id ;
  1. Zgłasza błąd, ponieważ lista kolumn GROUP BY nie pasuje do listy kolumn SELECT.
  2. Wykonuje z powodzeniem i generuje średnie wynagrodzenie na danej kategorii stanowisk w każdym dziale.
  3. Wykonuje z powodzeniem i generuje średnie wynagrodzenie dla działu w każdej kategorii pracy.
  4. Zgłasza błąd, ponieważ klauzule GROUP BY i ORDER BY mają różne listy kolumn.

Answer: B. Chociaż klauzula GROUP BY niejawnie sortuje grupy, klauzule GROUP BY i ORDER BY mogą być używane razem w zapytaniu.

57. Which clause should you use to exclude group results in a query using group functions?

  1. WHERE
  2. HAVING
  3. GRUPUJ WEDŁUG
  4. ZAMÓW PRZEZ

Answer: B. Klauzula HAVING służy do ograniczania grup.

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
  1. Wykonuje się pomyślnie.
  2. Zgłasza błąd, ponieważ klauzula HAVING poprzedza klauzulę GROUP BY.
  3. Zgłasza błąd, ponieważ klauzula HAVING używa funkcji agregującej.
  4. Wykonywany jest, ale nie są wyświetlane żadne wyniki, ponieważ klauzula HAVING poprzedza klauzulę GROUP BY.

Answer: A. Klauzula HAVING może poprzedzać klauzulę GROUP BY, ale jest przetwarzana dopiero po obliczeniu wyników grupy.

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;
  1. Zwraca błąd, ponieważ operator BETWEEN nie może być użyty w klauzuli HAVING.
  2. Zwraca błąd, ponieważ klauzule WHERE i HAVING nie mogą być używane w tej samej instrukcji SELECT.
  3. Zwraca błąd, ponieważ klauzule WHERE i HAVING nie mogą być używane do stosowania warunków w tej samej kolumnie.
  4. Wykonuje się pomyślnie.

Answer: D. Klauzula WHERE ogranicza liczbę wierszy uczestniczących w przetwarzaniu klauzuli grupy.

60. Which statements are true regarding the WHERE and HAVING clauses in a SELECT statement?

  1. Klauzula HAVING może być używana z funkcjami grupowymi w podzapytaniach.
  2. Klauzula WHERE może służyć do wykluczania wierszy po podzieleniu ich na grupy.
  3. Klauzula WHERE może służyć do wykluczania wierszy przed podzieleniem ich na grupy.
  4. Klauzul WHERE i HAVING można używać w tej samej instrukcji tylko wtedy, gdy są stosowane do różnych kolumn w tabeli.

Answer: A, C. W zapytaniu można używać razem klauzul WHERE i HAVING. WHERE wyklucza wiersze przed przetwarzaniem grupowym, a HAVING ogranicza grupy.

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 ;
  1. Zgłasza błąd, ponieważ funkcje agregujące użyte w klauzuli HAVING muszą znajdować się na liście SELECT.
  2. Zgłasza błąd, ponieważ klauzula HAVING pojawia się przed klauzulą ​​GROUP BY.
  3. Wyświetla działy, których średnie wynagrodzenie jest większe niż minimalne wynagrodzenie działu.
  4. Wyświetla działy, których średnie wynagrodzenie jest większe niż minimalne wynagrodzenie organizacji.

Answer: C. Funkcje grupowe mogą być używane przez klauzulę HAVING do filtrowania grup.

62. Interpret the output of the below query.

SELECT SUM(AVG(LENGTH(first_name )))
FROM employees  
GROUP BY department_id ;
  1. Oblicza sumę średnich długości nazwiska pracownika w każdym dziale.
  2. Oblicza średnią długość nazwiska pracownika w każdym dziale.
  3. Zgłasza błąd, ponieważ funkcji pojedynczego wiersza nie można używać z funkcjami grupowymi.
  4. Zgłasza błąd, ponieważ kolumna grupy DEPARTMENT_ID nie jest używana na liście SELECT.

Answer: A. Funkcje grupowe mogą być używane z funkcjami pojedynczymi wierszami lub funkcjami ogólnymi w zapytaniu SELECT.

63. Up to how many levels, the group functions can be nested?

  1. 1
  2. 2
  3. 3
  4. Bez limitów

Answer: B. Funkcje grupowe można zagnieżdżać maksymalnie na 2 poziomach. Jednak funkcje jednowierszowe można zagnieżdżać do dowolnej liczby poziomów.

64. What is the limit of number of groups within the groups created by GROUP BY clause?

  1. 1
  2. 2
  3. 3
  4. Bez limitu

Answer: D. Nie ma ograniczeń co do liczby grup i podgrup, które można utworzyć.

65. Choose the correct statements about the HAVING clause.

  1. Klauzula HAVING jest opcjonalną klauzulą ​​w instrukcji SELECT.
  2. Klauzula HAVING jest klauzulą ​​obowiązkową, jeśli instrukcja SELECT używa klauzuli GROUP BY.
  3. Klauzula HAVING może pojawić się w instrukcji SELECT tylko wtedy, gdy używa klauzuli GROUP BY.
  4. Klauzula HAVING jest klauzulą ​​obowiązkową, jeśli instrukcja SELECT używa klauzuli GROUP BY.

Answer: A, C. Klauzula HAVING może pojawić się w zapytaniu tylko wtedy, gdy występuje klauzula GROUP BY, ale na odwrót nie jest prawdą.

66. What is the output of the below query.

SELECT count(*) FROM dual GROUP BY dummy;
  1. 1
  2. 0
  3. NULL
  4. Zgłasza błąd, ponieważ nie można zastosować funkcji grupowych do tabeli DUAL.

Answer: A. Tabela DUAL zawiera pojedynczą kolumnę DUMMY typu CHAR (1) o wartości „X”.

Based on the below scenario, answer the question from 67 to 74.

Organizacja ma 14 pracowników, którzy pracują na stałą pensję w wysokości 1000. Firma rekrutuje 5 nowych pracowników, których wynagrodzenie nie jest jeszcze ustalone przez dział płac. Jednak w trakcie przetwarzania na koniec miesiąca dział kadr generuje kilka raportów w celu uzgodnienia danych finansowych organizacji. Sprawdź podaną strukturę tabeli.

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 ;
  1. NULL
  2. 14000
  3. 19000
  4. 0

Answer: B. Funkcja SUMA dodaje pensje pracowników.

68. What is the output of the below query?

SELECT AVG (salary ) FROM employees ;
  1. 1000
  2. 736.84
  3. NULL
  4. 0

Answer: A. Funkcja AVG (wynagrodzenie) oblicza średnią płac i ignoruje wartości NULL. W tym przypadku AVG (wynagrodzenie) = (14 * 1000) / 14 = 1000.

69. What is the output of the below query?

SELECT AVG (nvl(salary ,0)) FROM employees ;
  1. 1000
  2. NULL
  3. 736.84
  4. 0

Answer: C. AVG (NVL (wynagrodzenie, 0)) podaje alternatywną wartość zerowym wartościom i umożliwia im udział w obliczaniu średniej. W tym przypadku (14 * 1000) / 19 = 736,84.

70. What is the output of the below query?

SELECT VARIANCE (salary ) FROM employees ;
  1. 1000
  2. 0
  3. NULL
  4. 204678.36

Answer: B. VARIANCE (wynagrodzenie) oblicza wariancję wartości kolumny wynagrodzenia, ignorując wartości NULL.

71. What is the output of the below query?

SELECT VARIANCE (nvl(salary ,0)) FROM employees ;
  1. 1000
  2. 0
  3. NULL
  4. 204678.36

Answer: D. VARIANCE (NL (salary, 0)) oblicza wariancję wartości kolumny wynagrodzenia, w tym wartości NULL.

72. What is the output of the below query?

SELECT STDDEV (salary ) FROM employees ;
  1. 1
  2. 1000
  3. 0
  4. NULL

Answer: C. STDDEV (wynagrodzenie) oblicza odchylenie standardowe wartości kolumn wynagrodzenia, ignorując wartości NULL.

73. What is the output of the below query?

SELECT STDDEV (nvl(salary ,0)) FROM employees ;
  1. 0
  2. 452.41
  3. 1000
  4. NULL

Answer: B. STDDEV (nvl (salary, 0)) oblicza odchylenie standardowe wartości kolumny wynagrodzenia, w tym wartości NULL.

74. What is the output of the below query?

  1. 19,19
  2. 14,19
  3. 19,14
  4. 14,14

Answer: C. COUNT (*) obejmuje wartości NULL, a COUNT (wynagrodzenie) ignoruje wartości 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)

Które z poniższych pytań da dział, w którym pracuje więcej niż 5 pracowników?

  1. SELECT department_id  FROM employees  WHERE COUNT(*) > 5 GROUP BY department_id ;
  2. SELECT department_id  FROM employees  HAVING COUNT(*) > 5;
  3. SELECT department_id  FROM employees  GROUP BY employee_id  HAVING COUNT(*) > 5;
  4. 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?

  1. Umożliwia wykonywanie wielu klauzul GROUP BY za pomocą jednego zapytania.
  2. Wykonuje agregacje dla wszystkich możliwych kombinacji uwzględnionych kolumn.
  3. Wykonuje rosnące poziomy skumulowanych sum pośrednich na podstawie podanej listy kolumn.
  4. Żadne z powyższych

Answer: B. CUBE, ROLLUP to rozszerzenia GROUP BY używane do przetwarzania OLAP. CUBE agreguje wyniki za każdym razem, gdy tworzona jest nowa permutacja kolumny.

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. 1
  2. 3
  3. 4
  4. 5

Answer: B. Klauzula WHERE służy do ograniczania wierszy przed utworzeniem grup.

78. Which line of the SELECT statement is used to restrict groups displayed in the query results?

  1. 1
  2. 3
  3. 4
  4. 5

Answer: D. HAVING służy do ograniczenia wyników grupowych po zakończeniu przetwarzania grupowego.

79. Which line of the SELECT statement is used to group data stored in the database?

  1. 1
  2. 3
  3. 4
  4. 5

Answer: C. Klauzula GROUP BY używa grupowania według kolumn do grupowania danych w tabeli.

80. Which clause must be included for the query to execute successfully?

  1. 1
  2. 3
  3. 4
  4. 5

Answer: C. Ponieważ klauzula SELECT zawiera kolumnę CUSTOMER #, konieczne jest posiadanie klauzuli GROUP BY z kolumną CUSTOMER #.

81. What is the purpose of using COUNT(*) in the SELECT query?

  1. Liczba rekordów w określonych tabelach
  2. Liczba zamówień złożonych przez każdego klienta
  3. Liczba wartości NULL w określonych tabelach
  4. Liczba klientów, którzy złożyli zamówienie

Answer: B. Zlicza liczbę przetwarzanych wierszy w ramach grupy. W tym przypadku grupa jest tworzona przez klienta i LICZBA (*) zlicza zamówienia złożone przez każdego klienta.

82. Which of the following functions can be used to determine the earliest ship date for all orders recently processed by JustLee Books?

  1. LICZBA, funkcja
  2. Funkcja MAX
  3. Funkcja MIN
  4. Funkcja STDDEV

Answer: C. Funkcja MIN służy do pobierania najmniejszej wartości kolumny. W przypadku użycia z kolumnami dat pobiera minimalną datę z kolumny.

83. Which of the following is not a valid SELECT statement?

  1. SELECT STDDEV(retail) FROM books;
  2. SELECT AVG(SUM(retail)) FROM orders NATURAL JOIN orderitems NATURAL JOIN books GROUP BY customer#;
  3. SELECT order#, TO_CHAR(SUM(retail),'999.99') FROM orderitems JOIN books USING (isbn) GROUP BY order#;
  4. SELECT title, VARIANCE(retail-cost) FROM books GROUP BY pubid;

Answer: D. Klauzula GROUP BY musi określać kolumnę lub zestaw kolumn zawartych w klauzuli SELECT. Tutaj PUBID nie jest zawarty w klauzuli SELECT, dlatego zapytanie jest nieprawidłowe.

84. Which of the below statements are true about the nesting of group functions?

  1. Najbardziej wewnętrzna funkcja jest rozwiązywana jako pierwsza.
  2. Oracle umożliwia zagnieżdżanie funkcji grupowych do 3 poziomów.
  3. Funkcje jednorzędowe mogą być zagnieżdżane z funkcjami grupowymi.
  4. Oracle umożliwia zagnieżdżanie funkcji grupowych do 2 poziomów.

Answer: A, C, D. W wyrażeniu zawierającym funkcje zagnieżdżone, najbardziej wewnętrzna funkcja jest wykonywana jako pierwsza, której wynik jest przekazywany do następnej funkcji poruszającej się na zewnątrz. Funkcji jednorzędowych można dobrze używać z funkcjami grupowymi, które mogą być maksymalnie zagnieżdżone do 2 poziomów.

85. What are the statistical group functions in Oracle?

  1. AVG
  2. STDDEV
  3. VARIANCE
  4. STATS

Answer: B, C. VARIANCE i STATS to funkcje grup statystycznych dostępne w Oracle SQL.

86. If the SELECT list contains a column and a group functions, which of the following clause must be mandatorily included?

  1. ZAMÓW PRZEZ
  2. HAVING
  3. GRUPUJ WEDŁUG
  4. Żaden z tych

Answer: C. Klauzula GROUP BY musi koniecznie zawierać kolumnę lub zestaw kolumn zawartych w klauzuli 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)

Jakie jest najlepsze wyjaśnienie, dlaczego ta instrukcja SQL NIE jest wykonywana?

SELECT department_id "Department", AVG (salary)"Average"
FROM employees
GROUP BY Department;
  1. Wynagrodzeń nie można uśredniać, ponieważ nie wszystkie liczby będą się dzielić równo.
  2. W klauzuli GROUP BY nie można używać aliasu kolumny.
  3. Klauzula GROUP BY musi mieć coś do GROUP.
  4. Identyfikator działu nie jest wymieniony w tabeli działów.

Answer: B. Ani klauzula GROUP BY, ani klauzula HAVING nie działają z aliasami kolumn.

88. Which of the following data types are compatible with AVG, SUM, VARIANCE, and STDDEV functions?

  1. Tylko numeryczne typy danych
  2. Tylko liczby całkowite
  3. Dowolny typ danych
  4. Wszystkie oprócz liczb

Answer: A. Funkcje AVG, SUMA, VARIANCE i STDDEV obowiązkowo działają tylko z numerycznymi typami danych.

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?

  1. SELECT department_id , COUNT(DISTINCT job) FROM employees  GROUP BY job;
  2. SELECT department_id , COUNT(job) FROM employees  GROUP BY employee_id ;
  3. SELECT department_id , COUNT(job) FROM employees  GROUP BY department_id ;
  4. SELECT department_id , COUNT(DISTINCT job) FROM employees  GROUP BY department_id ;

Answer: D. Użyj modyfikatora DISTINCT, aby odfiltrować duplikaty.

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;

Dlaczego to stwierdzenie spowoduje błąd?

  1. Brakuje klauzuli HAVING.
  2. Klauzula WHERE zawiera błąd składniowy.
  3. Kolumna WYNAGRODZENIE NIE jest zawarta w klauzuli GROUP BY.
  4. Kolumna HIRE_DATE NIE jest uwzględniona w klauzuli GROUP BY.

Answer: D. Wszystkie kolumny występujące w klauzulach SELECT i ORDER BY muszą być uwzględnione w klauzuli GROUP BY.

91. Which of the following statements is true about the GROUP BY clause?

  1. Aby wykluczyć wiersze przed podzieleniem ich na grupy za pomocą klauzuli GROUP BY, należy użyć klauzuli powinno WHERE.
  2. Musisz użyć klauzuli HAVING z klauzulą ​​GROUP BY.
  3. Alias ​​kolumny może być używany w klauzuli GROUP BY.
  4. Domyślnie wiersze nie są sortowane, gdy używana jest klauzula GROUP BY.

Answer: A. Używając klauzuli WHERE, możesz wykluczyć wiersze przed podzieleniem ich na grupy.

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)

Zinterpretuj wynik poniższego zapytania.

SELECT department_id , MIN (hiredate)
FROM employees 
GROUP by department_id ;
  1. Najwcześniejsza data zatrudnienia w organizacji.
  2. Data ostatniego zatrudnienia w organizacji.
  3. Najwcześniejsza data zatrudnienia w dziale.
  4. Data ostatniego zatrudnienia w dziale.

Answer: C. Zapytanie zwraca najwcześniej zatrudnionego pracownika w każdym dziale.

93. Which statement about group functions is true?

  1. Funkcje grupowe z wyjątkiem COUNT (*), ignorują wartości null.
  2. Zapytanie zawierające funkcję grupy na liście SELECT musi zawierać klauzulę GROUP BY.
  3. Funkcje grupowe mogą być używane w klauzuli WHERE.
  4. Funkcje grupowe mogą być używane tylko na liście SELECT.

Answer: A. Wszystkie funkcje grupowe z wyjątkiem COUNT (*) ignorują wartości NULL. Dzieje się tak, ponieważ przetwarzają one wartości bezpośrednio zawarte w określonej kolumnie.

94. Which of the following clauses represent valid uses of group functions?

  1. GROUP BY MAX (wynagrodzenie)
  2. ORDER BY AVG (wynagrodzenie)
  3. MAJĄC MAKS (wynagrodzenie)> 10000
  4. SELECT AVG (NVL (wynagrodzenie, 0))

Answer: B, C, D. Funkcje grupowe mogą pojawiać się tylko w klauzulach SELECT, HAVING i ORDER BY.

95. Which of the following statements are true about the GROUP BY clause?

  1. Ostatnia kolumna wymieniona w klauzuli GROUP BY jest najważniejszą grupą.
  2. Pierwsza kolumna wymieniona w klauzuli GROUP BY jest najważniejszą grupą.
  3. Klauzuli GROUP BY nie można używać bez klauzuli ORDER BY.
  4. Klauzula GROUP BY nie zapewnia sortowania danych wyjściowych.

Answer: B. Grupowanie danych opiera się na sekwencji kolumn pojawiających się w klauzuli GROUP BY.

96. What is difference between WHERE clause and HAVING clause?

  1. Klauzula WHERE ogranicza wiersze przed grupowaniem, a klauzula HAVING ogranicza grupy.
  2. Klauzula WHERE nie może zawierać funkcji grupy, ale może zawierać klauzula HAVING.
  3. Klauzula WHERE może łączyć wiele warunków przy użyciu operatorów AND lub OR, ale klauzula HAVING nie może.
  4. Klauzula WHERE może pojawić się w zapytaniu SELECT bez klauzuli GROUP BY, ale klauzula HAVING nie.

Answer: A, B, D. WHERE klauzula ogranicza wiersze przed grupowaniem, ale HAVING ogranicza grupy.

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)

Przewidzieć wynik poniższego zapytania.

SELECT department_id ,job,count(*)
FROM employees 
GROUP BY department_id ,job
ORDER BY department_id ,count(*);
  1. Wykonuje się pomyślnie.
  2. Zgłasza błąd, ponieważ klauzula ORDER BY jest nieprawidłowa.
  3. Zgłasza błąd, ponieważ klauzula GROUP BY jest nieprawidłowa.
  4. Zgłasza błąd, ponieważ klauzule GROUP BY i ORDER BY nie mogą być używane razem.

Answer: A. Klauzula ORDER BY może używać funkcji grup do sortowania.