그룹 기능 질문 사용
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을 포함한 행 수를 계산합니다. 중복 및 NULL 값을 제한하려면 DISTINCT 및 ALL 키워드를 사용하십시오.
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을 포함한 행 수를 계산합니다. 중복 및 NULL 값을 제한하려면 DISTINCT 및 ALL 키워드를 사용하십시오.
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. COUNT (ALL 컬럼)은 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 열)는 고유 한 Null이 아닌 값을 계산합니다.
10. What happens when the below query is executed in SQL* Plus?
SELECT COUNT() FROM dual;
- 성공적으로 실행되고 출력이 반환되지 않습니다.
- 성공적으로 실행하고 출력을 '1'로 반환합니다.
- 예외 "ORA-00909 : 잘못된 인수 수"발생
- COUNT 함수가 DUAL 테이블에서 작동하지 않기 때문에 "ORA-00904 :"COUNT ": 잘못된 식별자"예외가 발생합니다.
Answer: C. COUNT 함수에는 [ALL | DISTINCT] 수정 자 또는 '*'.
11. Here are few statements about VARIANCE function in SQL.
나는. 이 함수는 여러 숫자 입력을 받아들이고 모든 값의 분산을 반환합니다.
ii. 이 함수는 숫자 열을 허용하고 NULL을 포함한 모든 열 값의 분산을 반환합니다.
iii. 이 함수는 숫자 열을 허용하고 NULL을 제외한 모든 열 값의 분산을 반환합니다.
아래 옵션에서 올바른 조합을 선택하십시오.- i 및 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은 그룹, 즉 부서에 대해 단일 값을 반환하기 때문에 단일 행 함수입니다.
- SUM은 GROUP BY 절을 사용하여 부서를 논리적으로 그룹화하므로 확장 별 그룹화 함수입니다.
Answer: A. SUM은 부서에서 일하는 직원 그룹의 급여 합계를 계산하는 그룹 함수입니다.
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. WHERE 조건을 사용하여 NULL을 제외하는 것은 쿼리가 NULL을 무시하도록 지시하는 방법입니다. 그러나 여기서 IS NULL 연산자의 사용법은 잘못되었습니다. 조건은 'WHERE comm IS NULL'이어야합니다.
16. Which of the following statements is true about the group functions?
- MIN 함수는 숫자 데이터에만 사용할 수 있습니다.
- MAX 함수는 날짜 값에만 사용할 수 있습니다.
- AVG 함수는 숫자 데이터에만 사용할 수 있습니다.
- SUM 함수는 중첩 함수의 일부가 될 수 없습니다.
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. HAVING 절이 GROUP BY 절 앞에 오면 Oracle은 오류를 발생시키지 않지만 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. 그룹 함수는 깊이 2까지만 중첩 될 수 있습니다. 그룹 함수는 단일 행 함수 (TO_CHAR 함수에 포함 된 AVG) 내에 중첩 될 수 있습니다. 또한 단일 행 함수는 그룹 함수 내에 중첩 될 수 있습니다.
24. Which of the following functions is used to calculate the total value stored in a specified column?
- COUNT
- ADD
- TOTAL
- SUM
Answer: D. SUM 함수는 숫자 값을 더하는 데 사용됩니다.
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를 제한해야하므로 테이블 행은 HAVING 절이 아닌 WHERE 절을 사용하여 필터링해야합니다.
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 (referred)는 열의 NULL 값을 무시합니다.
29. Determine the correct order of execution of following clauses in a SELECT statement.
1. 선택
2.FROM
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 절에 나타날 수 있습니다. 그룹 함수가 WHERE 또는 GROUP BY 절에서 사용되는 경우 Oracle은 예외를 발생시킵니다.
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 절이 없기 때문에 오류가 발생합니다.
- 성공적으로 실행되고 둘 다에 대해 동일한 값을 반환합니다.
- NULL을 포함한 COUNT (*)와 NULL을 제외한 COUNT (all comm)에서 성공적으로 실행됩니다.
Answer: D.
35. Which of the following are true about group functions?
- SELECT 문의 모든 절에서 그룹 함수를 사용할 수 있습니다.
- 그룹 함수는 select 절의 열 목록과 SELECT 문의 WHERE 절에서만 사용할 수 있습니다.
- 단일 행 열을 그룹화하여 SELECT 문의 열 목록에서 단일 행 열과 그룹 함수를 혼합 할 수 있습니다.
- 열 이름, 표현식, 상수 또는 함수를 매개 변수로 그룹 함수에 전달할 수 있습니다.
Answer: C. 그룹 함수는 깊이 2까지만 중첩 될 수 있습니다. 그룹 함수는 단일 행 함수 (TO_CHAR 함수에 포함 된 AVG) 내에 중첩 될 수 있습니다. 또한 단일 행 함수는 그룹 함수 내에 중첩 될 수 있습니다.
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 키워드가있는 하위 쿼리로 뷰가 생성되어 업데이트 될 수 있습니다.
- 테이블의 모든 NOT NULL 열이있는 하위 쿼리로 생성 된 뷰에서 DML (데이터 조작 언어) 작업을 수행 할 수 있습니다.
- 유사 열 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이 선택된 컬럼이 아니기 때문에 오류가 발생합니다. JOB 대신 DEPARTMENT_ID를 사용해야합니다.
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;
- 성공적으로 실행되고 필요한 결과를 생성합니다.
- SELECT 절에도 COUNT (*)를 지정해야하므로 오류가 발생합니다.
- 성공적으로 실행되지만 COUNT (*) 대신 COUNT (prod_id)를 사용해야하므로 결과가 생성되지 않습니다.
- COUNT (*)는 WHERE 절이 아닌 HAVING 절에만 있어야하므로 오류가 발생합니다.
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;
- 성공적으로 실행되고 각 작업 범주의 직원 수를 나열하지만 "salary"가 GROUP BY 절에 없기 때문에 HAVING 절을 무시합니다.
- HAVING 절이 유효하지 않기 때문에 오류가 발생합니다.
- GROUP BY 절에 "salary"가 포함되어 있지 않기 때문에 오류가 발생합니다.
- 성공적으로 실행되고 급여 합계가 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 함수는 EMPLOYEES 데이터의 그룹화를 기반으로하는 GROUP BY 절에 지정되어야합니다.
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. 첫 번째 쿼리는 전체 EMPLOYEES 데이터에 대해 작동하고 두 번째 쿼리는 부서 그룹의 데이터를 처리합니다.
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. HAVING 절에서 GROUP BY 식을 사용하여 최종 데이터 집합에서 그룹을 필터링 할 수 있습니다.
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이 COMM의 NULL 값을 고려하고 Query-2가 COMM의 NULL 값을 0으로 대체하기 때문에 다른 결과를 생성합니다.
- 쿼리-1은 COMM에 NULL 값이 있으므로 오류를 생성합니다.
- 쿼리-2는 NVL을 집계 함수로 중첩 할 수 없기 때문에 오류를 생성합니다.
Answer: B. AVG 함수는 숫자 데이터의 평균을 계산하는 동안 NULL 값을 무시합니다. AVG (column)은 null이 아닌 값에 대해서만 평균을 계산합니다. 그러나 NVL을 사용하여 NULL을 0으로 대체하면 모든 값이 고려됩니다.
55. Choose the correct statements about the GROUP BY clause.
- GROUP BY 절에서 열 별칭을 사용할 수 있습니다.
- GROUP BY 열은 SELECT 절에 있어야합니다.
- GROUP BY 절은 SELECT 쿼리의 HAVING 절과 함께 나타나야합니다.
- GROUP BY 절은 SELECT 쿼리에서 WHERE 절 뒤에 와야합니다.
Answer: D. 처리 순서에 따라 GROUP BY 절은 SELECT 쿼리에서 WHERE 절 뒤에 나타나야합니다.
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;
- HAVING 절에서 BETWEEN 연산자를 사용할 수 없기 때문에 오류를 반환합니다.
- 동일한 SELECT 문에서 WHERE 및 HAVING 절을 사용할 수 없기 때문에 오류를 반환합니다.
- 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 절은 GROUP BY 절을 사용하는 경우에만 SELECT 문에 나타날 수 있습니다.
- 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 테이블에는 값이 'X'인 CHAR (1) 유형의 단일 열 DUMMY가 있습니다.
Based on the below scenario, answer the question from 67 to 74.
한 조직에는 1,000 명의 고정 급여로 일하는 14 명의 직원이 있습니다. 회사는 급여 부서에서 급여를 아직 정하지 않은 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. SUM 함수는 직원의 급여를 추가합니다.
68. What is the output of the below query?
SELECT AVG (salary ) FROM employees ;
- 1000
- 736.84
- NULL
- 0
Answer: A. AVG (salary) 함수는 급여의 평균을 계산하고 NULL 값을 무시합니다. 이 경우 AVG (salary) = (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)는 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))는 NULL을 포함한 급여 열 값의 분산을 계산합니다.
72. What is the output of the below query?
SELECT STDDEV (salary ) FROM employees ;
- 1
- 1000
- 0
- NULL
Answer: C. STDDEV (salary)는 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))는 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은 OLAP 처리에 사용되는 GROUP BY 확장입니다. 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 절은 group by 열을 사용하여 테이블의 데이터를 그룹화합니다.
80. Which clause must be included for the query to execute successfully?
- 1
- 3
- 4
- 5
Answer: C. SELECT 절에 CUSTOMER # 열이 포함되어 있으므로 CUSTOMER # 열과 함께 GROUP BY 절이 있어야합니다.
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?
- COUNT 함수
- MAX 기능
- MIN 함수
- 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에 대한 내용이 있어야합니다.
- 부서 ID가 부서 테이블에 나열되지 않습니다.
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 절을 사용해야합니다.
- GROUP BY 절과 함께 HAVING 절을 사용해야합니다.
- 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 (*)를 제외한 그룹 함수는 null 값을 무시합니다.
- SELECT 목록에 그룹 함수를 포함하는 쿼리에는 GROUP BY 절이 포함되어야합니다.
- 그룹 함수는 WHERE 절에서 사용할 수 있습니다.
- 그룹 함수는 SELECT 목록에서만 사용할 수 있습니다.
Answer: A. COUNT (*)를 제외한 모든 그룹 함수는 NULL 값을 무시합니다. 특정 열에 직접 포함 된 값을 처리하기 때문입니다.
94. Which of the following clauses represent valid uses of group functions?
- GROUP BY MAX (급여)
- ORDER BY AVG (급여)
- HAVING MAX (급여)> 10000
- SELECT AVG (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 절은 GROUP BY 절없이 SELECT 쿼리에 나타날 수 있지만 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 절은 정렬을 위해 그룹 함수를 사용할 수 있습니다.