여러 테이블 질문에서 데이터 가져 오기
1.Which of the following is not related to a Relational Database?
- Selection
- Projection
- Joining
- 해당 사항 없음
Answer: D. 옵션 A, B 및 C는 Oracle Relational Database의 주요 기능입니다.
2.Which of the following methods is used for writing a query with columns from multiple tables?
- SELECT
- 그룹화
- 주문
- JOINS
Answer: D. 조인은 Oracle의 여러 테이블에서 여러 테이블과 프로젝트 열 데이터를 연결하는 데 사용됩니다.
3.Which of the following is one of the most common methods to join multiple tables?
- 해시 조인
- Equijoin
- 셀프 조인
- 교차 결합
Answer: B. Equijoin은 둘 이상의 테이블을 조인하는 가장 일반적이고 간단한 기술인 조인 유형 중 하나입니다. Equijoin은 단순 조인 또는 내부 조인이라고도하며, Equijoin에는 기본 키와 외래 키가 포함됩니다.
4.Which of following will be used to join rows with other tables if the column values fall in a range defined by inequality operators?
- Equijoin
- 간단한 조인
- Non-equijoin
- 해당 사항 없음
Answer: C. 동등 조인은 등호 연산자를 사용하여 행을 조인하고 비등가 조인은 부등 연산자를 사용합니다.
5.Which of the following statements is true about Oracle joins?
- 결과 집합에 NULL 값이 포함됩니다.
- 조건이 일치하는 행만 가져옵니다.
- 하나의 테이블에있는 모든 행이 페치됩니다.
- 해당 사항 없음
Answer: B. 조인이 사용될 때 공통 조인 열의 NULL 값과 다른 항목은 제외됩니다.
6.Which of the following can be used to join the rows of a table with other rows of the same table?
- Equijoin
- Non-equijoin
- 외부 결합
- Self-join
Answer: D. 연결은 논리적이고 일반적으로 서로 계층 적 관계가있는 열을 기반으로합니다.
7.What is true about a cartesian join of two tables in Oracle DB?
- 비용이 많이 들고 최적화되지 않으므로 피해야합니다.
- 한 테이블의 모든 행이 두 번째 테이블의 모든 행과 결합 될 때 형성됩니다.
- A 및 B 둘
- 해당 사항 없음
Answer: B. 카티 전 조인은 종종 조인 조건이 누락되거나 부적절한 결과로 발생하며 단순히 두 테이블의 교차 곱입니다.
8.Which of the following is one of the basic types of joins in Oracle DB ?
- 외부 결합
- Self-join
- Equi-join
- 무엇보다도
Answer: C. Equi-join과 non-equijoin은 Oracle DB의 두 가지 기본 조인 유형입니다.
9.What is the main condition for using joins between a source table and a target table in Oracle DB for getting a non-cartesian product result?
- 조건 없음
- 두 테이블의 열 중 적어도 하나는 공통이어야합니다.
- 조인을 사용하려면 두 조인 테이블의 열 이름이 동일해야합니다.
- 해당 사항 없음
Answer: B. 테이블은 두 엔터티와 관련된 공통 열을 통해 연결되어야합니다. 공통 열에 조인 된 테이블은 비 카티 전 곱을 생성합니다.
10. Which of the following can be used to fetch rows from multiple tables in a single SQL query?
- SELECT
- WHERE
- FROM
- Equi-joins
Answer: D. 동등 조인은 단순 조인 또는 내부 조인이라고도합니다. Equijoin에는 기본 키와 외래 키가 포함됩니다.
11.What is true about the source table and the target table in terms of Oracle Joins?
- 이름이 같은 열이 하나 이상 있어야합니다.
- 두 테이블을 결합하기 위해 모든 열은 이름과 데이터 유형이 동일해야합니다.
- 소스 및 대상 테이블은 스왑 할 수 없으며 위치에 따라 다릅니다.
- 해당 사항 없음
Answer: D. 원본 테이블과 대상 테이블은 교체 할 수 있으며 해당 위치에 고정되지 않습니다. 쿼리에 사용 된 조인 유형에 따라 결과가 다르거 나 동일하게 유지 될 수 있습니다.
12.What is true about Natural joins in Oracle DB?
- 소스 및 대상 테이블의 열 이름은 동일해야합니다.
- 소스 및 대상 테이블의 열 이름이 동일하지 않으면 Oracle은 암시 적으로 필요한 작업을 수행합니다.
- NATURAL JOINS, USING 및 ON은 Natural Join과 관련된 키워드입니다.
- 무엇보다도
Answer: C. NATURAL JOIN 키워드는 Oracle이 소스 테이블과 대상 테이블간에 동일한 이름을 가진 열을 식별하도록 지시합니다. 자연 조인은 이름과 데이터 유형이 일치하는 모든 열을 사용하여 테이블을 조인합니다. USING 절을 사용하여 동등 조인에 사용해야하는 열만 지정할 수 있습니다.
13.Assume the tables EMPLOYEES and DEPARTMENT have to be joined using NATURAL JOIN. What is the difference between the following two queries which follow? (Consider the table structures 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> 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)
SELECT department_id
FROM employees NATURAL JOIN department
WHERE first_name = 'John'
AND last_name = 'Bacon';
SELECT department_id
FROM department NATURAL JOIN employees
WHERE first_name = 'John'
AND last_name = 'Bacon';
- 다른 점이 없다
- 두 경우 모두 결과가 다릅니다.
- 두 쿼리 모두 실행시 ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: B. 관계 적으로 다른 결과 집합을 제공하는 NATURAL JOIN을 사용하는 동안 소스 및 대상 테이블을 스왑 할 수 있습니다.
14.Which of the following options is true regarding the NATURAL JOIN in Oracle DB?
- NATURAL JOIN을 사용하는 동안 두 테이블의 모든 열 이름을 언급하는 것은 필수입니다.
- NATURAL JOIN은 두 테이블의 모든 열 이름이 동일한 경우에만 사용할 수 있습니다.
- NATURAL JOIN의 조인은 사용자가 소스 및 대상 테이블의 열을 지정하는 경우에만 발생합니다.
- NATURAL JOINS를 사용할 때 열을 언급 할 필요가 없습니다.
Answer: D. NATURAL JOIN이 사용되는 경우 소스 및 대상 테이블의 열을 암시 적으로 조인합니다. NATURAL JOIN은 조인되는 두 테이블의 공통 열을 기반으로 암시 적 조인 절을 만드는 JOIN 작업입니다 .A NATURAL JOIN is a JOIN operation that creates an implicit join clause for you based on the common columns in the two tables being join. 공통 열은 두 테이블에서 동일한 이름을 가진 열입니다 .Common columns are columns that have the same name in both tables.
15. What is the difference between a NATURAL JOIN and a join with JOIN..ON?
- 둘 다 차이가 없습니다
- JOIN..ON은 이름이 같은 특정 열에서 소스 및 대상 테이블을 조인합니다.
- NATURAL JOIN은 소스 및 대상 테이블에서 일치하는 모든 열을 암시 적으로 조인합니다.
- 해당 사항 없음
Answer: B, C. 자연 조인에 대한 조인 조건은 기본적으로 동일한 이름을 가진 모든 열의 동등 조인입니다. ON 절을 사용하여 임의 조건을 지정하거나 조인 할 열을 지정합니다. 조인 조건은 다른 검색 조건과 구분됩니다. ON 절은 코드를 이해하기 쉽게 만듭니다.
16.What is true about the JOIN..ON clause in Oracle DB?
- 이름이 동일한 소스 및 대상 테이블의 열에 의존하지 않습니다.
- 동일한 이름을 가진 소스 및 대상 테이블의 열만이 절과 함께 사용할 수 있습니다.
- NATURAL JOIN의 형식입니다.
- 무엇보다도
Answer: A, C. 자연 조인에 대한 조인 조건은 기본적으로 동일한 이름을 가진 모든 열의 동등 조인입니다. ON 절을 사용하여 임의의 조건을 지정하거나 조인 할 열을 지정합니다. 조인 조건은 다른 검색 조건과 분리됩니다. ON 절은 코드를 이해하기 쉽게 만듭니다.
17. The database designer has named the key (unique) columns from two tables differently.While joining these tables, which among the following will be the best practice?
- JOIN..ON
- NATURAL JOIN 또는 JOIN ... ON 절
- A 및 B 둘
- 해당 사항 없음
Answer: A. 이 경우 NATURAL JOINS를 사용하면이 경우에는 존재하지 않는 동일한 이름을 가진 열을 암시 적으로 검색하므로 예기치 않은 결과가 발생할 수 있습니다.
18.What of the following can be used to fetch non-matching rows along with the matching rows between a source and a target table in Oracle DB?
- EQUI-JOIN
- SELF-JOIN
- 자연스러운 조인
- OUTER-JOIN
Answer: D. 외부 조인은 조인 테이블에 해당 레코드가없는 결과에 레코드를 포함해야하는 경우 생성됩니다. 이러한 레코드는 출력에 포함되도록 NULL 레코드와 일치합니다.
19. What are Cartesian Joins also known as in Oracle DB?
- Equi-join
- Anti-join
- Cross-Join
- 해당 사항 없음
Answer: C. 두 테이블 간의 카티 전 조인은 테이블에서 가능한 모든 행 조합을 반환합니다. 카티 전 조인은 쿼리에 조인 작업을 포함하지 않거나 CROSS JOIN을 사용하여 생성 할 수 있습니다.
20.What will be the result of a NATURAL JOIN between two tables EMPLOYEES and DEPARTMENT as given in the query below? (Consider the table structures 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> 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)
SELECT * FROM employees NATURAL JOIN department;
- 두 테이블에서 동일한 이름을 가진 공통 열 DEPARTMENT_ID가 결과 집합에 두 번 나타납니다.
- NATURAL JOIN으로 결합 된 동일한 이름을 가진 모든 열은 결과 집합에 두 번 나타납니다.
- 결과 집합에는 두 테이블의 동일하게 명명 된 열 쌍마다 하나의 열만 있습니다.
- 해당 사항 없음
Answer: C. NATURAL JOIN 키워드에는 두 테이블 간의 관계를 설정하기위한 조건이 필요하지 않습니다. 그러나 공통 열이 있어야합니다. 열 한정자는 NATURAL JOIN 키워드와 함께 사용할 수 없습니다.
21.What is the difference between a NATURAL JOIN and an EQUI-JOIN in Oracle DB?
- 다른 점이 없다
- 둘 다에서 얻은 결과 세트와 관련하여 동일합니다.
- A 및 B 둘
- 해당 사항 없음
Answer: D. NATURAL JOIN은 동일한 이름을 가진 모든 열을 조인하는 반면 EQUI-JOIN은 열이 SQL 쿼리에서 명시 적으로 언급되어야합니다.
22.What is an INNER JOIN in Oracle DB?
- 두 테이블간에 일치하는 레코드를 제공하는 조인을 INNER JOIN이라고합니다.
- 내부 조인은 <,>, <>와 같은 연산자를 사용할 수 있습니다.
- A 및 B 둘
- 해당 사항 없음
Answer: C. 조인은 반환 된 유일한 레코드가 모든 테이블에 일치하는 레코드를 갖는 내부 조인이거나 조인에 일치하는 레코드가 있는지 여부에 관계없이 레코드가 반환 될 수있는 외부 조인일 수 있습니다.
23.What is the difference between a INNER JOIN and an EQUI-JOIN in Oracle DB?
- 구문 및 얻은 결과 집합 측면에서 동일합니다.
- INNER JOIN은 EQUI-JOIN의 하위 집합입니다.
- INNER JOIN은 "="와 함께 <,>, <>와 같은 연산자를 사용할 수 있지만 EQUI-JOIN은 "="연산자 만 사용합니다.
- 무엇보다도
Answer: C. EQUI-JOIN은 조인 조건에서 "="연산자를 포함하는 INNER JOIN 유형이지만 INNER JOIN은 같음 및 비 균등 연산자를 모두 포함 할 수 있습니다.
24.What is true about NATURAL JOINS in terms of ANSI SQL: 1999 syntaxes in Oracle DB?
- 같음 연산자 (=)가 사용됩니다.
- 전통적인 구문과 비교할 때 다른 결과를 가져옵니다.
- ANSI SQL 구문은 SQL 쿼리에서 NATURAL JOIN과 같은 단어를 사용합니다.
- 위의 어느 것도 없습니다.
Answer: C. ANSI SQL 구문은 기존 방식에서 (=)를 사용하는 기존 방식과 다릅니다. ANSI SQL 구문에는 사용 된 조인을 구별하기 위해 NATURAL JOIN 등과 같은 키워드가 있습니다.
25.What of the following is true with respect to the query given below? (Consider the table structures 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> 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)
SELECT first_name, salary
FROM employees e, departments d
WHERE e.department_id (+) = d.department_id ;
- ANSI SQL의 Right Outer 조인과 동일한 두 테이블의 department_id 사이에 외부 조인이 있습니다.
- ANSI SQL의 Left Outer 조인과 동일한 두 테이블의 department_id 사이에 외부 조인이 있습니다.
- 일치 여부에 관계없이 직원 테이블에서 department_id의 모든 레코드를 가져옵니다.
- 일치 여부에 관계없이 부서 테이블에서 department_id의 모든 레코드를 가져옵니다.
Answer: A, D. 조건 e.department_id (+) = d.department_id는 Right Outer Join을 수행하고 부서 테이블의 모든 department_id가 일치 여부에 관계없이 표시됨을 의미합니다.
26.Which of the following syntax models is used in extensively in the software systems worldwide?
- ANSI SQL : 1999
- 기존 Oracle 구문과 ANSI SQL : 1999 구문
- 전통적인 Oracle 구문
- 모든 옵션
Answer: C. ANSI SQL : 1999 구문은 기존 Oracle 구문만큼 많이 사용되지는 않지만 여전히 Oracle SQL에서 사용할 수있는 구문 중 하나입니다.
27.What of the following is true regarding the Cartesian product in Oracle DB?
- 'N'이 조인 된 테이블의 수이면 아니요. 조인 수가 N-1이면 데카르트 곱이 수행되지 않습니다.
- 'N'이 조인 된 테이블의 수이면 아니요. 조인 수가 N이면 데카르트 곱이 수행됩니다.
- 'N'이 조인 된 테이블의 수이면 아니요. 조인 수는 N + 1, 데카르트 곱이 수행됩니다.
- 'N'이 조인 된 테이블의 수이면 아니요. 조인 수가 N-1 이하이면 데카르트 곱이 수행됩니다.
Answer: A. 두 테이블 간의 카티 전 조인은 테이블에서 가능한 모든 행 조합을 반환합니다. 카티 전 조인은 쿼리에 조인 작업을 포함하지 않거나 CROSS JOIN을 사용하여 생성 할 수 있습니다. 카티 전 곱을 방지하려면 쿼리에 최소한 (N-1) 개의 조인 조건이 있어야합니다. 여기서 N은 쿼리의 테이블 수입니다.
28.What is the reason of error in the following SQL query? (Consider the table structures 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> 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)
SELECT first_name, last_name
FROM employees, departments
WHERE department_id (+) = department_id ;
- 테이블에 사용 된 별칭이 없습니다.
- RIGHT OUTER JOIN이라는 단어는 여기서 사용되지 않으므로 오류가 발생합니다.
- (+)는 등식 조건의 왼쪽이 아니라 오른쪽에 있어야합니다.
- 모호한 이름 지정을 제거하려면 조건에서 department_id와 함께 테이블 별칭을 사용해야합니다.
Answer: D. 테이블 별칭이 없으면 Oracle은 조인되는 열의 출처를 파생 할 수 없으므로 실행시 모호성 오류가 발생합니다.
29.Which of the following is used to avoid the ambiguous column problem in Oracle DB?
- ;
- ,
- .
- /
Answer: C. 모호한 열 문제를 제거하기위한 구문은 다음과 같습니다. table_alias.column_name
30.Which of the following is the most appropriate about the following query? (Consider the table structures 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> 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)
SELECT employee_id , first_name, last_name
FROM employees e right outer join department d
On e.department_id = d.department_id ;
- 부서에없는 직원에 대한 세부 정보를 제공합니다.
- 직원이없는 부서에 대한 세부 정보를 제공합니다.
- 직원 유무에 관계없이 모든 부서의 세부 정보를 제공합니다.
- 부서에 관계없이 'ABC'사에 채용 된 직원에 대한 세부 정보를 제공합니다.
Answer: C. 외부 조인에 대한 JOIN 메서드를 사용하여 LEFT, RIGHT 또는 FULL 키워드를 추가 할 수 있습니다. 왼쪽 외부 조인에는 조인 작업에서 다른 테이블과 일치하는 항목이없는 경우에도 조인의 왼쪽에 나열된 테이블의 모든 레코드가 포함됩니다. 전체 외부 조인에는 다른 테이블에 해당 레코드가없는 경우에도 두 테이블의 모든 레코드가 포함됩니다.
31.What will be the outcome of the following query? (Consider the table structures 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> 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)
SELECT *
FROM employees e, department d
WHERE a.department_id = b.department_id ;
- department_id가 동일한 두 테이블에서 일치하는 모든 값을 제공합니다.
- 직원 테이블의 모든 열과 부서 테이블의 상위 100 개 행만 제공합니다.
- ORA 오류가 발생합니다 : "b.department_id"유효하지 않은 식별자
- 위 옵션 없음
Answer: C. FROM 절에서 선언 된 것과 동일한 별칭이 WHERE 절에 있어야합니다.
32.Which of the following is true regarding the USING and ON clauses in table joins? (Choose more than one options if applicable)
- ON 절을 사용하여 데이터 유형은 동일하지만 반드시 이름이 같은 열의 테이블을 조인 할 수 있습니다.
- USING 및 ON 절은 동등 조인 및 비 동등 조인에만 사용됩니다.
- ON 절에는 둘 이상의 조건을 사용할 수 없습니다.
- 추가 조건을 적용하기 위해 USING..ON 절 뒤에 WHERE 절을 작성할 수 있습니다.
Answer: A, D. JOIN ... USING 접근 방식은 공통 열이 USING 절에 지정된다는 점을 제외하고 NATURAL JOIN 접근 방식과 유사합니다. 테이블이 관련되는 방식을 나타내는 조건은 USING 절에 포함될 수 없습니다. 또한 USING 절에 지정된 공통 열에는 열 한정자를 사용할 수 없습니다. JOIN ... ON 접근 방식은 지정된 조건에 따라 테이블을 조인합니다. FROM 절의 JOIN 키워드는 조인 할 테이블을 나타내고 ON 절은 두 테이블이 관련되는 방식을 나타냅니다. 조인되는 테이블에 각 테이블에 동일한 이름을 가진 공통 열이없는 경우이 방법을 사용해야합니다.
33.How many tables can be joined by using the JOINS in Oracle DB?
- 1
- 2
- 255
- 제한 없음
Answer: D. 현재 조인에 참여하는 테이블 수에는 제한이 없습니다.
34. What is true when multiple joins are used in an SQL statement?
- 조인은 왼쪽에서 오른쪽으로 평가됩니다.
- 조인은 오른쪽에서 왼쪽으로 평가됩니다.
- 조인 평가 프로세스에는 우선 순위가 없습니다.
- 해당 사항 없음
Answer: A. 문에 다중 조인이 있으면 왼쪽에서 오른쪽으로 평가됩니다.
35.What is true with respect to the following query? (Consider the table structures 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> 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> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
SELECT bonus, first_name, department_id
FROM bonus b NATURAL JOIN employees e NATURAL JOIN department d;
- NATURAL JOIN을 사용하여 여러 테이블을 조인하는 것이 더 나은 옵션이며 정확한 결과를 산출합니다.
- NATURAL JOIN을 사용하여 여러 테이블을 조인하면 오류 확률이 매우 낮습니다.
- USING..JOIN..ON 절은 여러 테이블을 조인 할 때 NATURAL JOIN보다 더 정확한 결과를 제공합니다.
- Oracle은 NATURAL JOIN이 사용될 때 암시 적으로 여러 테이블을 조인하므로 NATURAL JOINS를 사용하는 것이 좋습니다.
Answer: C. NATURAL JOINS를 사용하면 행의 데카르트 곱을 만들 수 있으며 의존 할 수없는 결과 집합에서 오류가 발생하기 쉽습니다.
36.What is true about the clauses JOIN..ON in Oracle DB?
- 여러 테이블을 조인 할 때 NATURAL JOINS와 비교할 때 그다지 신뢰할 수 없습니다.
- JOIN..ON 절은 조건으로 행을 제한하는 WHERE 절과 유사합니다.
- JOIN..ON 절을 사용하는 경우 추가 WHERE 절이 필수입니다.
- 해당 사항 없음
Answer: B. JOIN .... ON 접근 방식은 지정된 조건에 따라 테이블을 조인합니다. FROM 절의 JOIN 키워드는 조인 할 테이블을 나타내고 ON 절은 두 테이블이 관련되는 방식을 나타냅니다. 조인되는 테이블에 각 테이블에 동일한 이름을 가진 공통 열이없는 경우이 방법을 사용해야합니다.
Examine the table structures as given. Answer the questions 37 and 38 that follow the query given below:
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> 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)
SELECT e.salary, d.department_id
FROM employees e JOIN department d
On (e.department_id = d.department_id and e.last_name = 'Brandon');
37.What is true with respect to the query given above?
- 필수 WHERE 절이 없기 때문에 ORA 오류가 발생합니다.
- JOIN..ON 절은 둘 이상의 조건을 포함 할 수 없습니다.
- 쿼리는 마지막 조건을 무시하고 ORA 오류없이 실행됩니다.
- JOIN..ON 절은 더 많은 조건을 입력하기 위해 위에 주어진 형식으로 작성할 수 있습니다.
Answer: D. WHERE 절은 생략 할 수 있으며 주어진 쿼리에 표시된대로 JOIN..ON 절 자체에 관련 조건을 수용 할 수 있습니다.
38.With respect to the given query, if the JOIN used is replaced with NATURAL JOIN, it throws an error. What is the reason for this error?
- NATURAL JOIN을 사용하는 경우 WHERE 절이 필수이며 생략하면 오류가 발생합니다.
- ON 절은 USING 절로 바꿔야합니다.
- NATURAL, JOIN 및 USING이라는 단어는 동일한 조인 절의 컨텍스트에서 상호 배타적으로 사용됩니다.
- 쿼리는 조인하는 동안 NATURAL JOIN 및 ON (또는 USING) 절을 결합 할 수 없습니다.
Answer: C, D.
39.What is true about Non-equijoins in Oracle DB?
- 키워드 NON-EQUI JOIN을 기반으로 참여합니다.
- "="기호와 함께 JOIN..ON 절을 사용하여 사용됩니다.
- 언급 된 부등식의 결과가 참으로 평가 될 때 결과가 얻어집니다.
- 해당 사항 없음
Answer: C. 비동 등 조인은 JOIN..ON 절과 함께 사용되지만 부등 연산자와 함께 사용됩니다.
Examine the structures of the tables EMPLOYEES and DEPARTMENTS as given and answer the questions 40 and 41 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)
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)
40.What will be the outcome of the following query in Oracle DB?
SELECT e.first_name, e.last_name, e.employee_id
FROM employees e JOIN department d
ON (e.salary BETWEEN 1000 AND 10000);
- ON 절의 조건이 올바르지 않기 때문에 ORA 오류가 발생합니다.
- ON 절에 등호 "="가 없으므로 구문 오류로 인해 ORA 오류가 발생합니다.
- 성공적으로 실행되고 언급 된 조건을 가진 직원의 이름, 성 및 직원 ID를 제공합니다.
- 같지 않은 조인은 범위가 아닌 같지 않음을 표시하는 데만 사용할 수 있습니다.
Answer: C.
41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) AND d.loc = upper ('Geneva');
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000);
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000) AND d.loc = 'Geneva';
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) WHERE d.loc = upper('Geneva');
Answer: A, C.
42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?
- 부등식 일치 연산의 결과가 참입니다.
- 부등식 일치 연산의 결과는 0입니다.
- 부등식 일치 연산의 결과는 1입니다.
- 부등식 일치 연산의 결과가 거짓입니다.
Answer: A. 동등 조인은 서로 다른 두 테이블의 레코드를 결합하는 데이터가 정확히 일치 할 때 생성됩니다 (즉, 동일 조건이 관계를 생성 함). 기존 접근 방식은 WHERE 절에서 비교 연산자로 등호를 사용합니다. JOIN 접근 방식은 NATURAL JOIN, JOIN ... USING 또는 JOIN ... ON 키워드를 사용할 수 있습니다.
41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) AND d.loc = upper ('Geneva');
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000);
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000) AND d.loc = 'Geneva';
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) WHERE d.loc = upper('Geneva');
Answer: A, C.
42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?
- 부등식 일치 연산의 결과가 참입니다.
- 부등식 일치 연산의 결과는 0입니다.
- 부등식 일치 연산의 결과는 1입니다.
- 부등식 일치 연산의 결과가 거짓입니다.
Answer: A. 동등 조인은 서로 다른 두 테이블의 레코드를 결합하는 데이터가 정확히 일치 할 때 생성됩니다 (즉, 동일 조건이 관계를 생성 함). 기존 접근 방식은 WHERE 절에서 비교 연산자로 등호를 사용합니다. JOIN 접근 방식은 NATURAL JOIN, JOIN ... USING 또는 JOIN ... ON 키워드를 사용할 수 있습니다.
41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) AND d.loc = upper ('Geneva');
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000);
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000) AND d.loc = 'Geneva';
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) WHERE d.loc = upper('Geneva');
Answer: A, C.
42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?
- 부등식 일치 연산의 결과가 참입니다.
- 부등식 일치 연산의 결과는 0입니다.
- 부등식 일치 연산의 결과는 1입니다.
- 부등식 일치 연산의 결과가 거짓입니다.
Answer: A. 동등 조인은 서로 다른 두 테이블의 레코드를 결합하는 데이터가 정확히 일치 할 때 생성됩니다 (즉, 동일 조건이 관계를 생성 함). 기존 접근 방식은 WHERE 절에서 비교 연산자로 등호를 사용합니다. JOIN 접근 방식은 NATURAL JOIN, JOIN ... USING 또는 JOIN ... ON 키워드를 사용할 수 있습니다.
41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) AND d.loc = upper ('Geneva');
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000);
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000) AND d.loc = 'Geneva';
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) WHERE d.loc = upper('Geneva');
Answer: A, C.
42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?
- 부등식 일치 연산의 결과가 참입니다.
- 부등식 일치 연산의 결과는 0입니다.
- 부등식 일치 연산의 결과는 1입니다.
- 부등식 일치 연산의 결과가 거짓입니다.
Answer: A. 동등 조인은 서로 다른 두 테이블의 레코드를 결합하는 데이터가 정확히 일치 할 때 생성됩니다 (즉, 동일 조건이 관계를 생성 함). 기존 접근 방식은 WHERE 절에서 비교 연산자로 등호를 사용합니다. JOIN 접근 방식은 NATURAL JOIN, JOIN ... USING 또는 JOIN ... ON 키워드를 사용할 수 있습니다.
43.What is true regarding a Self-Join in Oracle DB?
- 조인이 작동하려면 두 개의 테이블 만 필요합니다.
- 결과 집합의 열은 두 테이블에서 가져 오지만 하나의 테이블에 표시됩니다.
- 개념적으로 소스 테이블은 자신을 복제하여 대상 테이블을 만듭니다. (Oracle은 테이블을 복제하지 않습니다)
- 무엇보다도
Answer: C. 자체 조인은 필요한 데이터를 검색하기 위해 테이블을 자체 조인해야 할 때 사용됩니다. 셀프 조인을 수행하려면 FROM 절에 테이블 별칭이 필요합니다.
44. With respect to the query and the table structure given below,answer the question.
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 *
FROM employees a join employees b
WHERE a.employee_id = b.employee_id ;
다음 중 Oracle이 소스 테이블과 대상 테이블로 취급하는 테이블은 무엇입니까?
- a는 소스이고 b는 대상입니다.
- b는 소스이고 a는 대상입니다.
- Oracle은 어떤 테이블도 소스 또는 대상으로 취급하지 않습니다.
- 해당 사항 없음
Answer: A. 직원 테이블의 첫 번째 발생은 소스로, 후속 발생은 b, c 등으로 간주됩니다.
45.In what scenarios can we use Self-Joins ideally in Oracle DB?
- 테이블에서 중복 레코드를 찾아야 할 때
- 테이블에서 NULL 값을 얻어야 할 때
- 테이블 열을 두 번 표시해야 할 때
- 관련 엔티티의 계층을 표시해야 할 때
Answer: D.
46. What is true about NATURAL JOINS in Oracle DB?
- 결합 된 열은 이름이 같지만 데이터 유형이 다를 수 있습니다.
- 결합 된 열은 동일한 데이터 유형이지만 다른 이름을 가질 수 있습니다.
- 결합 된 열은 이름과 데이터 유형이 동일해야합니다.
- 해당 사항 없음
Answer: C. NATURAL JOIN 키워드에는 두 테이블 간의 관계를 설정하기위한 조건이 필요하지 않습니다. 그러나 공통 열이 있어야합니다. 열 한정자는 NATURAL JOIN 키워드와 함께 사용할 수 없습니다 .Column qualifiers ca n't be used with the NATURAL JOIN keyword.
47.A report has to be extracted which gives the department name, department ID, department city and location ID only for departments 100 and 101. Using NATURAL JOINS, which of the following options will give the required results?
SELECT department_id , department_name ,location, city FROM departments NATURAL JOIN locations WHERE department_id in (100,101);
SELECT department_id , department_name ,location, city FROM locations NATURAL JOIN departments WHERE department_id BETWEEN 100 AND 101;
-
SELECT department_id , department_name ,location, city FROM departments NATURAL JOIN locations WHERE department_id >100 AND department_id >101;
-
SELECT department_id , department_name ,location, city FROM departments NATURAL JOIN locations ;
Answer: A. WHERE는 NATURAL JOIN 절 이후의 추가 조건에 사용할 수 있습니다.
48.In which of the following scenarios shall a USING clause or a NATURAL JOIN clause be used?
- 테이블의 컬럼 이름이 동일하면 USING 절을 사용하십시오.
- 테이블의 열 데이터 유형이 동일하면 NATURAL JOINS를 사용하십시오.
- 여러 열의 이름이 같지만 데이터 유형이 일치하지 않는 경우 USING을 사용할 수 있습니다.
- NATURAL JOINS는 열 이름과 해당 데이터 유형이 동일한 경우에만 사용해야합니다.
Answer: C, D. NATURAL JOINS 및 USING은 상호 배타적이므로 둘 이상의 열이 일치하는 경우 USING 절을 사용하여 하나의 열만 일치시켜야합니다.
49.Examine the table structures given. What will be the outcome of the following query? (Choose the most appropriate answer)
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> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
SELECT e.name, b.bonus
FROM employees e
JOIN bonus b
USING (job_id)
WHERE e.job_id like 'SA%');
- 일부 회사의 모든 직원이 얻은 이름과 보너스를 제공합니다.
- 회사의 특정 직책에있는 모든 직원이 얻은 이름과 보너스를 제공합니다.
- 모든 직무에서 모든 직원이 얻은 모든 이름과 보너스를 성공적으로 제공합니다.
- ORA 오류가 발생합니다.
Answer: D. USING 절에 사용 된 컬럼은 SQL 문 어디에도 규정 자 (테이블 이름 또는 별명)가 없어야합니다.
50.What is true with respect to INNER JOINS and OUTER JOINS in Oracle DB?
- INNER JOIN은 일치하는 행만 반환합니다.
- OUTER JOIN은 일치하지 않는 행만 반환합니다.
- OUTER JOIN은 일치하는 행과 일치하지 않는 행을 반환합니다.
- 해당 사항 없음
Answer: A, C. 조인은 반환 된 유일한 레코드에 모든 테이블에 일치하는 레코드가있는 내부 조인이거나 조인에 일치하는 레코드가 있는지 여부에 관계없이 레코드가 반환 될 수있는 외부 조인일 수 있습니다. 조인 테이블에 해당 레코드가 없어도 결과에 레코드가 포함되어야합니다. 이러한 레코드는 출력에 포함되도록 NULL 레코드와 일치합니다.
51. What is true regarding FULL OUTER JOIN in Oracle DB?
- LEFT OUTER JOIN과 RIGHT OUTER JOIN이 같은 쿼리에 모두 나타날 때이를 FULL OUTER JOIN이라고합니다.
- FULL OUTER JOIN은 OUTER JOIN과 동일합니다.
- A 및 B 둘
- INNER 조인과 LEFT 및 RIGHT OUTER JOIN의 결과를 반환하는 두 테이블 간의 조인을 FULL OUTER JOIN이라고합니다.
Answer: D. 전체 외부 조인에는 다른 테이블에 해당 레코드가없는 경우에도 두 테이블의 모든 레코드가 포함됩니다.
Examine the given table structures and answer the questions 52 and 53 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)
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> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
52.Consider the following query.
SELECT e.job_id , e.first_name, d.department_id
FROM departments D JOIN employees e JOIN BONUS b
USING (job_id );
이 쿼리로 인해 오류가 발생합니다. 오류의 원인은 무엇입니까?
- JOIN..USING은 한 번에 두 테이블 사이에서만 발생할 수 있습니다.
- 쿼리의 USING 절에 부서의 열이 없습니다.
- 쿼리에 WHERE 절이 없습니다.
- 해당 사항 없음
Answer: A. Table1 JOIN table2 JOIN table3은 각 JOIN 사이에 ON 절이 없으면 허용되지 않습니다.
53.You need to display all the non-matching rows from the EMPLOYEES table and the non-matching rows from the DEPARTMENT table without giving a Cartesian product of rows between them. Which of the following queries will give the desired output?
SELECT * FROM employees e, department d WHERE e.department_id = d.department_id ;
SELECT * FROM employees e NATURAL JOIN department d;
SELECT * FROM employees e FULL OUTER JOIN department d ON e.department_id = d.department_id ;
SELECT * FROM employees e JOIN department d ON ( e.department_id > d.department_id ) ;
Answer: C. FULL OUTER JOIN은 두 테이블 모두에서 일치하지 않는 행을 반환합니다. 전체 외부 조인에는 다른 테이블에 해당 레코드가없는 경우에도 두 테이블의 모든 레코드가 포함됩니다.
54.Which of the following ANSI SQL: 1999 join syntax joins are supported by Oracle?
- 데카르트 곱
- 자연 조인
- 전체 외부 조인
- Equijoins
Answer: D.
55.Which of the following is not a format for Outer Joins in Oracle DB?
- Right
- Left
- Centre
- Full
Answer: C. 'Centre'를 제외하고 나머지 3 가지 유형은 Oracle DB의 Outer Joins 형식입니다. 외부 조인에 대한 JOIN 메서드를 사용하여 LEFT, RIGHT 또는 FULL 키워드를 추가 할 수 있습니다.
Examine the given table structures. Answer the questions 56, 57 and 58 that follow by referring to 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)
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)
SELECT *
FROM employees e NATURAL JOIN department d;
56.You need to find the results obtained by the above query only for the departments 100 and 101. Which of the following clauses should be added / modified to the above query?
- ON (e.department_id = d.department_id)을 추가해야합니다.
- USING (e.department_id)을 추가해야합니다.
- (100,101)의 e.department_id를 추가해야하는 위치
- 해당 사항 없음
Answer: C. NATURAL JOIN 절은 동일한 명명 된 모든 열과 암시 적으로 일치합니다. 추가 조건을 추가하려면 WHERE 절을 사용할 수 있습니다.
57.You need to find the results obtained by the above query for all those employees who have salaries greater than 20000. Which of the following clauses should be added / modified to the above query?
- ON (e.department_id = d.department_id) WHERE 급여> 20000;
- USING (e.department_id) WHERE 급여> 20000;
- USING (department_id) WHERE salary> 20000;
- WHERE 급여> 20000;
Answer: D.
58.If the NATURAL JOIN in the above query is replaced by only JOIN which of the following should be added / modified to the above query to give the results pertaining to Department 100?
- ON (department_id = 100);
- USING (e.department_id = 100);
- 어디서 d.department_id = 100;
- ON (e.department_id = d.department_id 및 d.department_id = 100);
Answer: D. ON 절 뒤에 더 많은 조건을 위해 동등 조인을 추가 할 수 있습니다.
59.A report has to be extracted to get the Managers for all the employees in the departments 10 and 20 of a company 'ABC'. Which of the following queries will give the required results? (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 a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees" FROM employees a join employees b On (employee_id );
SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees" FROM employees a join employees b On (b.employee_id = a.employee_id );
SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees" FROM employees a join employees b On (a.manager_id = b.employee_id ) WHERE department_id in (10,20);
SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees" FROM employees a join employees b On (a.manager_id = b.employee_id ) WHERE a.department_id in (10,20);
Answer: D. WHERE 절의 별칭이 지정되지 않은 department_id가 오류를 발생 시키므로 옵션 C가 올바르지 않습니다.
60.Which of the following queries will give results without duplicate values between the two tables EMPLOYEES and DEPARTMENT? (Consider the table structures 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> 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)
SELECT * FROM employees e NATURAL JOIN department d;
SELECT * FROM employees e JOIN department d;
SELECT * FROM employees e NATURAL JOIN department d USING (e.department_id );
SELECT * FROM employees e FULL OUTER JOIN department d USING (department_id );
Answer: D. FULL OUTER JOIN은 중복 값을 제외하고 두 테이블에서 일치하지 않는 모든 행을 제공합니다.
Examine the structures for the tables as given here and answer the questions 61 to 64.
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> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
SQL> desc locations
Name Null? Type
----------------------- -------- ----------------
LOCATION_ID NOT NULL NUMBER(4)
STREET_ADDRESS VARCHAR2(40)
POSTAL_CODE VARCHAR2(12)
CITY NOT NULL VARCHAR2(30)
STATE_PROVINCE VARCHAR2(25)
COUNTRY_ID CHAR(2)
SQL> desc locations
Name Null? Type
----------------------- -------- ----------------
LOCATION_ID NOT NULL NUMBER(4)
STREET_ADDRESS VARCHAR2(40)
POSTAL_CODE VARCHAR2(12)
CITY NOT NULL VARCHAR2(30)
STATE_PROVINCE VARCHAR2(25)
COUNTRY_ID CHAR(2)
61.What is true about the following query? (Choose the most appropriate answer)
SELECT *
FROM bonus b, employees e
WHERE b.job_id (+) = e.job_id ;
- 모든 직원이 획득 한 모든 보너스가 표시됩니다.
- 특정 직원이 보너스를받지 못한 경우 보너스 열에 NULL이 표시됩니다.
- A 및 B 둘
- 해당 사항 없음
Answer: B. 방정식의 LHS에있는 (+)는 RIGHT OUTER JOIN이고 그 반대의 경우도 마찬가지입니다.
62.You have to list all the departments who have no employees yet in a company named 'XYZ'. Which of the following queries will give you the required results?
SELECT department_id , department_name FROM departments d NATURAL JOIN employees e;
SELECT department_id , department_name FROM employees e JOIN departments d ON (e.department_id = d.department_id );
SELECT department_id , department_name FROM employees e LEFT OUTER JOIN departments d USING (department_id );
SELECT department_id , department_name FROM employees e RIGHT OUTER JOIN departments d ON (e.department_id = d.department_id );
Answer: D.
63.You need to extract a report which displays 'No department yet' for all those employees who are yet to be allocated to a department. Which of the following will fulfill the purpose?
SELECT nvl(department_id ,'No department yet') FROM employees e RIGHT OUTER JOIN departments d ON (e.department_id = d.department_id );
SELECT nvl(department_id ,'No department yet') FROM departments d LEFT OUTER JOIN employees e ON (e.department_id = d.department_id );
SELECT nvl(department_id ,'No department yet') FROM employees e LEFT OUTER JOIN departments d ON (e.department_id = d.department_id );
SELECT nvl(department_id ,'No department yet') FROM employees e FULL OUTER JOIN departments d ON (e.department_id = d.department_id );
Answer: C.
64.You need to extract a report which displays all the departments which have not been assigned to a city yet. Which of the following queries will give you the required output?
SELECT department_id , department_name FROM departments d NATURAL JOIN locations l;
SELECT department_id , department_name FROM departments d FULL OUTTER JOIN locations l ON (d.location_id = l.location_id);
SELECT d.department_id , d.department_name FROM departments d JOIN locations l USING (location_id);
SELECT department_id , department_name FROM departments d LEFT OUTER JOIN locations l ON (d.location_id = l.location_id);
Answer: D.
65.In which two cases an OUTER JOIN should be used?
- 조인 된 테이블의 열에 NULL 값이있는 경우
- 조인 된 테이블에 NOT NULL 열이있는 경우
- 조인 된 테이블에 일치하지 않는 데이터 만있는 경우
- 조인 된 테이블에 일치하는 데이터와 일치하지 않는 데이터가 모두있는 경우
Answer: A, D. 외부 조인은 조인 테이블에 해당 레코드가없는 결과에 레코드를 포함해야하는 경우 생성됩니다. 이러한 레코드는 출력에 포함되도록 NULL 레코드와 일치합니다.
66.You need to find the salary grade obtained by each employee. Which of the following query will you use? (Consider the table structures 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> desc grade
Name Null? Type
----------------------- -------- ----------------
GRADE NUMBER
LOSAL NUMBER
HISAL NUMBER
SELECT employee_id , salary, grade FROM employees e JOIN grade g ON g.grade BETWEEN g.losal AND g.hisal
SELECT employee_id , salary, grade FROM employees e FULL OUTER JOIN grade g WHERE g.grade > g.losal AND < g.hisal;
SELECT employee_id , salary, grade FROM employees e JOIN grade g ON (MIN(g.grade) = g.losal AND MAX(g.grade) = g.hisal);
- 해당 사항 없음
Answer: A.
67.Examine the table structures 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> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
이 SQL 문을 평가하십시오.
SELECT e.employee_id , (.25* e.salary) + (.5 * e.commission_pct) + (.75 * b.bonus) as calc_val
FROM employees e, bonus b
WHERE e.employee_id = b.employee_id ;
계산에서 모든 괄호를 제거하면 어떻게됩니까?
- calc_val 열에 표시되는 값은 더 적습니다.
- calc_val 열에 표시된 값이 더 높아집니다.
- calc_val 열에는 차이가 없습니다.
- 오류가보고됩니다.
Answer: C.
68.Consider the exhibit and examine the structures of the EMPLOYEES, DEPARTMENTS, and GRADE tables. For which situation would you use a non-equijoin query?
- 각 직원의 등급을 찾으려면
- 모든 직원의 이름, job_id 및 관리자 이름을 나열하려면
- 직원의 부서 이름을 찾으려면.
- 관리 부서에서 일하고 수입이 30000 미만인 직원 수를 찾으려면
Answer: A. 비동 등 조인은 동일 조건 이외의 다른 항목을 기반으로 관계를 설정합니다. 비동 등 조인에 사용되는 범위 값은 상호 배타적이어야합니다.
69.In which three cases would you use the USING clause? (Choose three.)
- 비 동등 조인을 작성하려고합니다.
- 조인 할 테이블에 여러 NULL 열이 있습니다.
- 조인 할 테이블에는 이름이 같고 데이터 유형이 다른 열이 있습니다.
- NATURAL 조인을 사용하고 싶지만 조인 조건에서 열 수를 제한하려고합니다.
Answer: C, D. JOIN .... USING 접근 방식은 공통 열이 USING 절에 지정된다는 점을 제외하면 NATURAL JOIN 접근 방식과 유사합니다. 테이블이 관련되는 방식을 나타내는 조건은 USING 절에 포함될 수 없습니다. 또한 USING 절에 지정된 공통 열에는 열 한정자를 사용할 수 없습니다.
70.If the tables EMPLOYEES and BONUS have two columns with identical names viz: - SALARY and JOB_ID, which of the following queries are equivalent to each other? (Consider the table structures 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> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
SELECT * FROM employees E JOIN bonus B on (salary, job_id )
SELECT * FROM employees E NATURAL JOIN bonus B on (salary, job_id )
SELECT * FROM employees E JOIN bonus B USING (salary, job_id )
SELECT * FROM employees E JOIN bonus B on (salary, job_id )
Answer: B, C.
71.Examine the table structures 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> 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 문을 검토하십시오.
Query 1SELECT first_name,department_id
FROM employees E JOIN departments D
USING (department_id );
Query 2
SELECT first_name,department_id
FROM employees E NATURAL JOIN departments D
USING (department_id );
결과에 대해 옳은 진술은 무엇입니까?
- 쿼리 1 만 성공적으로 실행되고 필요한 결과를 제공합니다.
- 쿼리 2 만 성공적으로 실행되고 필요한 결과를 제공합니다.
- 쿼리 1과 2는 모두 성공적으로 실행되고 다른 결과를 제공합니다.
- 쿼리 1과 2는 모두 성공적으로 실행되고 동일한 필수 결과를 제공합니다.
Answer: D.
72.You need to generate a report showing the department location along with the employee name for all hires made before 20th January, 2013.
다음 쿼리를 실행합니다.
SELECT department_name , first_name||' '||last_name
FROM employees E JOIN department d
ON ( hire_date < '20-JAN-2013')
JOIN locations L
ON (l.location_id = d.location_id) ;
위 쿼리와 관련하여 올바른 설명은 무엇입니까?
- 성공적으로 실행되고 필요한 결과를 제공합니다.
- 성공적으로 실행되지만 필요한 결과를 제공하지 않습니다.
- 테이블의 조인 순서가 잘못되어 오류가 발생합니다.
- equijoin 및 non-equijoin 조건은 동일한 SELECT 문에서 사용할 수 없기 때문에 오류가 발생합니다.
Answer: B.
73.Examine the structure of the EMPLOYEES table:
중복 된 이름을 모두 나열하여 다른 EMPLOYEE_ID를 사용하여 직원의 세부 정보가 두 번 이상 입력되었는지 확인하려고합니다. 필요한 결과를 얻기 위해 어떤 방법을 사용할 수 있습니까?
- self-join
- 셀프 조인을 사용한 전체 외부 조인
- 셀프 조인이있는 왼쪽 외부 조인
- 셀프 조인이있는 오른쪽 외부 조인
Answer: A. 자체 조인은 필요한 데이터를 검색하기 위해 테이블을 자체 조인해야 할 때 사용됩니다. 셀프 조인을 수행하려면 FROM 절에 테이블 별칭이 필요합니다.
Examine the structure of the tables DEPARTMENTS and LOCATIONS and answer the questions 74 and 75 that follow.
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> desc locations
Name Null? Type
----------------------- -------- ----------------
LOCATION_ID NOT NULL NUMBER(4)
STREET_ADDRESS VARCHAR2(40)
POSTAL_CODE VARCHAR2(12)
CITY NOT NULL VARCHAR2(30)
STATE_PROVINCE VARCHAR2(25)
COUNTRY_ID CHAR(2)
74.You need to find out the departments that have not been allocated any location. Which query would give the required result?
SELECT d.department_id , d.department_name FROM departments d JOIN locations l ON (d.location_id = l.location_id);
SELECT d.department_id , d.department_name FROM departments d RIGHT OUTER JOIN locations l ON (d.location_id = l.location_id);
SELECT d.department_id , d.department_name FROM departments d FULL JOIN locations l ON (d.location_id = l.location_id);
SELECT d.department_id , d.department_name FROM departments d LEFT OUTER JOIN locations l ON (d.location_id = l.location_id);
Answer: B.
75.You want to list all departments that are not located in any location along with the department name. Evaluate the following query:
SELECT d.department_id , d.department_name ,l.location_id, l.city
FROM departments D __________________ location L
ON (d.location_id = l.location_id);
올바른 출력을 제공하기 위해 위 쿼리의 공백에 사용할 수있는 두 가지 JOIN 옵션은 무엇입니까?
- JOIN
- 자연스러운 조인
- 왼쪽 외부 조인
- 오른쪽 외부 조인
Answer: A, C.
76. You need to generate a report that shows all department IDs, with corresponding employees (if any) and bonus details (if any), for all employees. Which FROM clause gives the required result? (Consider the table structures 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> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
- 부서 LEFT OUTER (department_id) FULL OUTER JOIN 보너스를 사용하여 직원 가입
- 전체 외부 조인 부서 사용 (department_id);
- FROM 보너스 JOIN 직원 USING (job_id)
- 직원 전체 외부 참여 부서 전체 외부 참여 보너스
Answer: A.
77. Examine the following exhibits:
커미션이 있는지 여부에 따라 직원의 ID와 해당 커미션 및 부서 (있는 경우)를 나열하는 보고서를 생성하려고합니다. 다음 쿼리를 평가하십시오.
SELECT e.employee_id , bonus, department_name FROM bonus b_____________ employees
USING (job_id ) ____________ departments
USING (department_id )
WHERE commission_pct IS NOT NULL;
위 쿼리의 공백에 사용 된 조인 조합이 올바른 출력을 제공합니까?
- 어울리다; 왼쪽 외부 조인
- 완전한 외부 조인; 전체 외부 조인
- 오른쪽 외부 조인; 왼쪽 외부 조인
- 왼쪽 외부 조인; 오른쪽 외부 조인
Answer: A.
78.Predict the outcome of the following query.
SELECT e.salary, bonus
FROM employees E JOIN bonus b
USING (salary,job_id );
- 성공적으로 실행됩니다.
- SELECT의 보너스가 별칭이 아니기 때문에 오류가 발생합니다.
- USING 절은 둘 이상의 열을 가질 수 없기 때문에 오류가 발생합니다.
- 성공적으로 실행되지만 결과가 올바르지 않습니다.
Answer: D.
View the Exhibit and examine the structure of the EMPLOYEES, DEPARTMENTS, LOCATIONS and BONUS. Answer the questions from 79 and 80 that follow:
79.You need to list all the departments in the city of Zurich. You execute the following query:
SELECT D.DEPARTMENT_ID , D.DEPARTMENT_NAME , L.CITY
FROM departments D JOIN LOCATIONS L
USING (LOC_ID,CITY)
WHERE L.CITY = UPPER('ZURICH');
위 쿼리의 결과를 예측합니다.
- 성공적으로 실행됩니다.
- SELECT 문에서 CITY에 규정자가 사용되므로 오류가 발생합니다.
- SELECT의 열 이름이 일치하지 않기 때문에 오류가 발생합니다.
- USING 절에 일치하는 컬럼이 아닌 CITY가 있으므로 오류가 발생합니다.
Answer: D. USING 절에는 일치하는 열 이름 만 사용해야합니다.
80.Answer the question that follows the query given below:
SELECT e.first_name, d.department_id , e.salary, b.bonus
FROM bonus b join employees e
USING (job_id )
JOIN department d
USING (department_id )
WHERE d.loc = 'Zurich';
ABC라는 회사 직원의 이름, 부서 번호, 급여 및 보너스를 제공하는 보고서를 추출해야합니다. 다음 중 목적을 해결할 수있는 쿼리는 무엇입니까?
SELECT e.first_name, d.department_id , e.salary, b.bonus FROM bonus b join employees e join departments d on (b.job_id = e.job_id ) on (e.department_id =d.department_id ) WHERE d.loc = 'Zurich';
SELECT e.first_name, d.department_id , e.salary, b.bonus FROM bonus b join employees e on (b.job_id = e.job_id ) JOIN department d on (e.department_id =d.department_id ) WHERE d.loc = 'Zurich';
SELECT e.first_name, d.department_id , e.salary, b.bonus FROM employees e join bonus b USING (job_id ) JOIN department d USING (department_id ) WHERE d.loc = 'Zurich';
- 해당 사항 없음
Answer: C. 쿼리 A는 구문 오류를 발생시키고 쿼리 B는 보너스와 부서간에 잘못된 식별자 오류를 발생시킵니다.
Examine the Exhibits given below and answer the questions 81 to 85 that follow.
81. You need to find the managers' name for those employees who earn more than 20000. Which of the following queries will work for getting the required results?
SELECT e.employee_id "Employee", salary, employee_id , FROM employees E JOIN employees M USING (e.manager_id = m.employee_id ) WHERE e.salary >20000;
SELECT e.employee_id "Employee", salary, employee_id , FROM employees E JOIN employees M USING (e.manager_id) WHERE e.salary >20000;
SELECT e.employee_id "Employee", salary, employee_id , FROM employees E NATURAL JOIN employees M USING (e.manager_id = m.employee_id ) WHERE e.salary >20000;
SELECT e.employee_id "Employee", salary, employee_id , FROM employees E JOIN employees M ON (e.manager_id = m.employee_id ) WHERE e.salary >20000;
Answer: D.
82.You issue the following query:
SELECT e.employee_id ,d.department_id
FROM employees e NATURAL JOIN department d NATURAL JOIN bonus b
WHERE department_id =100;
이 쿼리의 결과와 관련하여 올바른 설명은 무엇입니까?
- 성공적으로 실행됩니다.
- NATURAL 조인은 두 개의 테이블에서만 사용할 수 있으므로 오류가 발생합니다.
- NATURAL 조인에 사용 된 열은 한정자를 가질 수 없기 때문에 오류가 발생합니다.
- NATURAL 조인에 사용되는 모든 열에는 한정자가 있어야하므로 오류가 발생합니다.
Answer: C.
83.You want to display all the employee names and their corresponding manager names. Evaluate the following query:
SELECT e.first_name "EMP NAME", m.employee_name "MGR NAME"
FROM employees e ______________ employees m
ON e.manager_id = m.employee_id ;
필요한 출력을 얻기 위해 위 쿼리의 공백에 어떤 JOIN 옵션을 사용할 수 있습니까?
- 간단한 내부 JOIN
- 전체 외부 조인
- 왼쪽 외부 조인
- 오른쪽 외부 조인
Answer: C. 왼쪽 외부 조인에는 조인 작업에서 다른 테이블과 일치하는 항목이없는 경우에도 조인의 왼쪽에 나열된 테이블의 모든 레코드가 포함됩니다.
Consider the below exhibit and following query to answer questions 84 and 85. (Assume the table department has manager_id and department_name as its columns)
Select *
FROM employees e JOIN department d
ON (e.employee_id = d.manager_id);
84. You need to display a sentence "(first_name) (last_name) is manager of the (department_name) department". Which of the following SELECT statements will successfully replace '*' in the above query to fulfill this requirement?
SELECT e.first_name||' '||e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
SELECT e.first_name, e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
SELECT e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
- 해당 사항 없음
Answer: A.
85.What will happen if we omit writing the braces "( )" after the ON clause in the above query?
- 직원의 이름 만 제공되며 관리자의 이름은 결과 집합에서 제외됩니다.
- 중괄호 "()"와 동일한 결과를 제공합니다.
- JOIN..ON 절을 사용할 때 중괄호 "()"를 반드시 작성해야하므로 ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: B. 중괄호는 필수는 아니지만 사용하면 그 안의 조건을 명확하게 읽을 수 있습니다.
86. Which of the following queries creates a Cartesian join?
SELECT title, authorid FROM books, bookauthor;
SELECT title, name FROM books CROSS JOIN publisher;
SELECT title, gift FROM books NATURAL JOIN promotion;
- 무엇보다도
Answer: A, B. 두 테이블 간의 카티 전 조인은 테이블에서 가능한 모든 행 조합을 반환합니다. 카티 전 조인은 쿼리에 조인 작업을 포함하지 않거나 CROSS JOIN을 사용하여 생성 할 수 있습니다.
87. Which of the following operators is not allowed in an outer join?
- AND
- =
- OR
- >
Answer: C. Oracle에서 "ORA-01719 : OR 또는 IN의 피연산자에 외부 조인 연산자 (+)가 허용되지 않음"예외가 발생했습니다.
88. Which of the following queries contains an equality join?
SELECT title, authorid FROM books, bookauthor WHERE books.isbn = bookauthor.isbn AND retail > 20;
SELECT title, name FROM books CROSS JOIN publisher;
SELECT title, gift FROM books, promotion WHERE retail >= minretail AND retail <= maxretail;
- 해당 사항 없음
Answer: A. 서로 다른 두 테이블의 레코드를 결합하는 데이터가 정확히 일치하는 경우 (즉, 동일 조건이 관계를 생성하는 경우) 동등 조인이 생성됩니다.
89. Which of the following queries contains a non-equality join?
SELECT title, authorid FROM books, bookauthor WHERE books.isbn = bookauthor.isbn AND retail > 20;
SELECT title, name FROM books JOIN publisher USING (pubid);
SELECT title, gift FROM books, promotion WHERE retail >= minretail AND retail <= maxretail;
- 해당 사항 없음
Answer: D. 비동 등 조인은 비 균등 식을 기반으로 다른 테이블의 열 값과 일치합니다. 소스 테이블의 각 행에있는 조인 열의 값은 대상 테이블의 해당 값과 비교됩니다. 부등식 연산자를 기반으로 조인에 사용 된 표현식이 true로 평가되면 일치가 발견됩니다. 이러한 조인이 생성되면 nonequijoin이 수행되고, nonequijoin은 JOIN..ON 구문을 사용하여 지정되지만 조인 조건에는 등호 대신 부등 연산자가 포함됩니다.
90. The following SQL statement contains which type of join?
SELECT title, order#, quantity
FROM books FULL OUTER JOIN orderitems
ON books.isbn = orderitems.isbn;
- equality
- self-join
- non-equality
- 외부 결합
Answer: D. 전체 외부 조인에는 다른 테이블에 해당 레코드가없는 경우에도 두 테이블의 모든 레코드가 포함됩니다.
91. Which of the following queries is valid?
SELECT b.title, b.retail, o.quantity FROM books b NATURAL JOIN orders od NATURAL JOIN orderitems o WHERE od.order# = 1005;
SELECT b.title, b.retail, o.quantity FROM books b, orders od, orderitems o WHERE orders.order# = orderitems.order# AND orderitems.isbn=books.isbn AND od.order#=1005;
SELECT b.title, b.retail, o.quantity FROM books b, orderitems o WHERE o.isbn = b.isbn AND o.order#=1005;
- 해당 사항 없음
Answer: C. 조인의 테이블에 별칭이있는 경우 선택한 열은 실제 테이블 이름이 아닌 별칭으로 참조되어야합니다.
92. Given the following query.
SELECT zip, order#
FROM customers NATURAL JOIN orders;
다음 중 동일한 쿼리는 무엇입니까?
SELECT zip, order# FROM customers JOIN orders WHERE customers.customer# = orders.customer#;
SELECT zip, order# FROM customers, orders WHERE customers.customer# = orders.customer#;
SELECT zip, order# FROM customers, orders WHERE customers.customer# = orders.customer# (+);
- 해당 사항 없음
Answer: B. 자연 조인은 Oracle이 소스 테이블과 대상 테이블간에 동일한 이름을 가진 열을 식별하도록 지시합니다.
93. Examine the table structures as given. Which line in the following SQL statement raises an error?
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> 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)
1. SELECT e.first_name, d.department_name
2. FROM employees e, department d
3. WHERE e.department_id=d.department_id
- 라인 1
- 2 호선
- 3 행
- 오류 없음
Answer: A. 쿼리가 조인 조건에서 별칭 이름을 사용하는 경우 해당 열은 참조를 위해 별칭을 사용해야합니다.
94. Given the following query:
SELECT lastname, firstname, order#
FROM customers LEFT OUTER JOIN orders
USING (customer#)
ORDER BY customer#;
다음 쿼리 중 동일한 결과를 반환하는 쿼리는 무엇입니까?
SELECT lastname, firstname, order# FROM customers c OUTER JOIN orders o ON c.customer# = o.customer# ORDER BY c.customer#;
SELECT lastname, firstname, order# FROM orders o RIGHT OUTER JOIN customers c ON c.customer# = o.customer# ORDER BY c.customer#;
SELECT lastname, firstname, order# FROM customers c, orders o WHERE c.customer# = o.customer# (+) ORDER BY c.customer#;
- 해당 사항 없음
Answer: B, C.
95. Which of the below statements are true?
- 여러 데이터 소스의 데이터에 대해 그룹 함수를 사용할 수 없습니다.
- 쿼리에 조인 된 여러 테이블에 동일한 열이 포함 된 경우 Oracle은 그중 하나만 선택합니다.
- 자연 조인은 동일한 열을 기반으로 두 테이블의 행을 조인하는 데 사용됩니다.
- A와 B
Answer: C. Oracle 조인을 사용하는 쿼리에서 그룹 함수를 사용할 수 있습니다. 한정자를 사용하여 모호한 열을 참조해야합니다.
96. Which line in the following SQL statement raises an error?
1. SELECT name, title
2. FROM books JOIN publisher
3. WHERE books.pubid = publisher.pubid
4. AND
5. cost < 45.95
- 라인 1
- 2 호선
- 3 행
- 4 행
Answer: C. JOIN 키워드를 사용하여 테이블을 조인하기 때문에 WHERE 절이 아닌 USING 절로 동등 조건을 작성해야합니다.
97. Given the following query:
SELECT title, gift
FROM books CROSS JOIN promotion;
다음 중 동일한 쿼리는 무엇입니까?
SELECT title, gift FROM books NATURAL JOIN promotion;
SELECT title FROM books INTERSECT SELECT gift FROM promotion;
SELECT title FROM books UNION ALL SELECT gift FROM promotion;
SELECT title, gift FROM books, promotion;
Answer: D. 데카르트 조인은 교차 조인과 동일합니다.
98. If the CUSTOMERS table contains seven records and the ORDERS table has eight records, how many records does the following query produce?
SELECT *
FROM customers CROSS JOIN orders;
- 0
- 56
- 7
- 15
Answer: B. 교차 조인은 두 테이블에 포함 된 행의 교차 곱입니다.
99. Which of the following SQL statements is not valid?
SELECT b.isbn, p.name FROM books b NATURAL JOIN publisher p;
SELECT isbn, name FROM books b, publisher p WHERE b.pubid = p.pubid;
SELECT isbn, name FROM books b JOIN publisher p ON b.pubid = p.pubid;
SELECT isbn, name FROM books JOIN publisher USING (pubid);
Answer: A. 모호한 열은 테이블 한정자로 참조해야합니다.
100. Which of the following lists all books published by the publisher named 'Printing Is Us'?
SELECT title FROM books NATURAL JOIN publisher WHERE name = 'PRINTING IS US';
SELECT title FROM books, publisher WHERE pubname = 1;
SELECT * FROM books b, publisher p JOIN tables ON b.pubid = p.pubid WHERE name = 'PRINTING IS US';
- 해당 사항 없음
Answer: A. NAME 열이 BOOKS 테이블에 포함되어 있지 않다고 가정하면 쿼리 A가 유효합니다.
101. Which of the following SQL statements is not valid?
SELECT isbn FROM books MINUS SELECT isbn FROM orderitems;
SELECT isbn, name FROM books, publisher WHERE books.pubid (+) = publisher.pubid (+);
SELECT title, name FROM books NATURAL JOIN publisher
- 위의 모든 SQL 문이 유효합니다.
Answer: B. 쿼리 B에서 "ORA-01468 : 술어는 하나의 외부 조인 테이블 만 참조 할 수 있습니다"예외가 발생합니다.
102. Which of the following statements about an outer join between two tables is true?
- WHERE 절을 사용하여 테이블 간의 관계를 설정하면 두 테이블 모두 외부 조인 연산자를 포함 할 수 있습니다.
- 결과에 일치하지 않는 레코드를 포함하기 위해 레코드는 결함이있는 테이블의 NULL 레코드와 쌍을 이룹니다.
- RIGHT, LEFT 및 FULL 키워드는 동일합니다.
- 무엇보다도
Answer: B.
103. Which line in the following SQL statement raises an error?
1. SELECT name, title
2. FROM books b, publisher p
3. WHERE books.pubid = publisher.pubid
4. AND
5. (retail > 25 OR retail-cost > 18.95);
- 라인 1
- 3 행
- 4 행
- 5 행
Answer: B. 쿼리에 사용 된 테이블에는 한정자가 있으므로 동일한 열을 사용하여 참조해야합니다.
104. What is the maximum number of characters allowed in a table alias?
- 10
- 155
- 255
- 30
Answer: D. 테이블 별칭은 최대 30 자일 수 있습니다.
105. Which of the following SQL statements is valid?
SELECT books.title, orderitems.quantity FROM books b, orderitems o WHERE b.isbn= o.ibsn;
SELECT title, quantity FROM books b JOIN orderitems o;
SELECT books.title, orderitems.quantity FROM books JOIN orderitems ON books.isbn = orderitems.isbn;
- 해당 사항 없음
Answer: C.