데이터 질문 조작
1.What does ACID mean with respect to relational database?
- 정확성, 일관성, 격리, 데이터베이스
- 정확성, 동시성, 격리, 내구성
- 원 자성, 일관성, 격리, 내구성
- 원 자성, 동시성, 격리, 내구성
Answer: C. 모든 Oracle 트랜잭션은 ACID 속성으로 알려진 데이터베이스 트랜잭션의 기본 속성을 따릅니다. 원자 성은 트랜잭션의 모든 작업이 수행되거나 수행되지 않음을 나타냅니다. 부분 거래가 없습니다. 일관성은 트랜잭션이 데이터베이스를 하나의 일관성있는 상태에서 다른 일관성있는 상태로 가져옴을 의미합니다. 격리는 트랜잭션이 커밋 될 때까지 트랜잭션의 효과가 다른 트랜잭션에 표시되지 않음을 의미합니다. 내구성은 커밋 된 트랜잭션에 의한 변경이 영구적임을 의미합니다. 트랜잭션이 완료된 후 데이터베이스는 복구 메커니즘을 통해 트랜잭션의 변경 사항이 손실되지 않도록합니다.
2. What does the word DML stands for in Oracle SQL?
- 내구성 관리 언어
- 데이터베이스 관리 언어
- 데이터베이스 조작 언어
- 해당 사항 없음
Answer: C. DML은 데이터 조작 언어를 나타냅니다.
3. Which of the following are DML commands in Oracle Database?
- SELECT
- 그룹화
- INTERSECT
- INSERT
Answer: A, D. 엄격한 근거에서 SELECT는 테이블에있는 데이터 조작을위한 필수 절 중 하나이므로 DML 명령입니다.
4.Which of the following DML commands can be considered to be a hybrid of INSERT and UPDATE in a single statement?
- INTERSECT
- INSERT
- SELECT
- MERGE
Answer: D. MERGE는 Oracle의 단일 문에서 INSERT 및 UPDATE 작업을 수행 할 수 있습니다.
5. What all operations can MERGE statement perform in SQL?
- INSERT
- DELETE
- 그룹화
- 해당 사항 없음
Answer: A, B. 일부 조건에서 MERGE는 INSERT 및 UPDATE와 함께 DELETE 작업도 수행 할 수 있습니다.
6.Which of following commands is a DDL (Data Definition Language) command but is often considered along with DML commands?
- DELETE
- INSERT
- TRUNCATE
- 해당 사항 없음
Answer: C. TRUNCATE는 DDL 명령입니다. 조건없이 테이블에서 레코드를 제거합니다. 진행중인 트랜잭션의 일부가 아니며 TRUNCATE가 실행 된 후 세션에서 커밋되지 않은 트랜잭션이 커밋됩니다.
7.Which of the following commands manipulate data basically?
- MINUS
- UPDATE
- TRUNCATE
- 무엇보다도
Answer: B, C. UPDATE는 테이블의 열 값을 수정하는 DML 문입니다. TRUNCATE는 테이블에서 데이터를 무조건 제거하여 데이터를 조작합니다.
8. Which of the following commands is used to populate table rows with data?
- DELETE
- INSERT
- SELECT
- UPDATE
Answer: B. INSERT 명령은 테이블에 행을 삽입하는 데 사용됩니다.
9. What is true about the INSERT statement? (Choose the most appropriate answer)
- 한 번에 한 테이블의 한 행에 데이터를 삽입 할 수 있습니다.
- 한 번에 한 테이블의 여러 행에 데이터를 삽입 할 수 있습니다.
- 한 번에 여러 테이블의 여러 행에 데이터를 삽입 할 수 있습니다.
- 무엇보다도
Answer: C. INSERT 문은 한 번에 단일 테이블에 행 또는 행 세트를 삽입 할 수 있습니다.
10.What is true about the insertion of rows in tables?
- 행을 임의로 삽입 할 수 있습니다.
- 제한없이 테이블에 원하는 수의 행을 삽입 할 수 있습니다.
- 일반적으로 제약 조건으로 알려진 특정 규칙에 따라 테이블에 행이 삽입됩니다.
- 무엇보다도
Answer: C. 제약 조건은 열에 들어오는 데이터의 동작을 보장하기 위해 열에 적용되는 비즈니스 규칙입니다. 이러한 제약 조건은 INSERT 프로세스 중에 데이터에 대해 유효성이 검사됩니다.
11. What is true about the INSERT statement in Oracle SQL? (Choose the most appropriate answer)
- INSERT 문은 테이블에 대한 제약 조건을 무시할 수 있습니다.
- 제약 조건이 이미 테이블에 배치 된 경우 테이블에서 INSERT 문을 사용할 수 없습니다.
- INSERT 문은 제약 조건이 이미 테이블에있는 경우에만 테이블에서 사용할 수 있습니다.
- INSERT 문은 제약 조건을 위반하는 행을 삽입 할 수 없습니다.
Answer: D. Oracle은 insert 문에 포함 된 데이터가 제약 조건을 위반하는 경우 예외를 발생시킵니다.
Consider the following data set from the EMPLOYEES table along with its structure and answer the questions 12, 13 and 14:
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)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE CLERK
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
12. Examine the structure of the EMPLOYEES table. You issue the following command:
INSERT INTO EMPLOYEES (employee_id , first_name , job_id) VALUES (5100, 'BRUCE', 'CLERK');
EMPLOYEE_ID 열에 중복 값 검사 제약이 있다고 가정 할 때 위 명령문의 결과는 무엇입니까?
- 5100 BRUCE CLERK 값이있는 다른 행을 삽입합니다.
- 51002 BRUCE CLERK 값이있는 다른 행을 삽입합니다.
- '제한 위반'ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: C. 값이 "5100, BRUCE, CLERK"인 행이 이미 테이블에 존재하므로 동일한 데이터 세트를 가진 삽입 명령문이 불가능합니다.
13.You issue the following command to the data set shown above:
INSERT INTO EMPLOYEES (employee_id , first_name , job_id) VALUES (51003,'BRUCE','CLERK');
이 진술의 결과는 무엇입니까?
- 51003 BRUCE CLERK 값이있는 새 행을 삽입합니다.
- CLERK 인 다른 BRUCE가있을 수 없으므로 ORA 오류가 발생합니다.
- '제한 위반'ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: A. FIRST_NAME 및 job_id 열에는 제약이 없으므로 INSERT는 오류없이 작동합니다.
14. You issue the following command to the data set shown above:
INSERT INTO EMPLOYEES (employee_id , first_name , job_id ) VALUES (51003,'BRUCE', NULL);
이 진술의 결과는 무엇입니까?
- 51003 BRUCE CLERK 값이있는 새 행을 삽입합니다.
- CLERK 인 다른 BRUCE가있을 수 없으므로 ORA 오류가 발생합니다.
- '제한 위반'ORA 오류가 발생합니다.
- 51003 BRUCE NULL 값이있는 새 행을 삽입합니다.
Answer: D. FIRST_NAME 및 JOB_ID 열에는 NOT NULL 제약 조건이 없으므로 NULL 값이 삽입됩니다.
15. What among the following can be said regarding inserting of rows in tables?
- 사용자는 대화식으로 행을 삽입 할 수 없습니다.
- 사용자가 행을 대화식으로 삽입하기위한 대체 변수로 쿼리를 작성할 수 있습니다.
- 사용자에게 행을 삽입하라는 메시지가 표시되면 삽입이 작동하지 않고 ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: B. INSERT 문은 대체 변수를 사용하여 런타임 동안 사용자에게 값을 입력하라는 메시지를 표시 할 수 있습니다. 테이블에 데이터를 삽입하는 대화 형 방법을 제공합니다.
16.Which of the following can be used to insert rows in tables?
- SELECT
- INSERT
- Sub-queries
- 무엇보다도
Answer: D. INSERT 문은 명시 적 INSERT, INSERT-SELECT 또는 하위 쿼리 메서드를 사용하여 테이블에 데이터를 삽입 할 수 있습니다.
17. Which among the following is a common technique for inserting rows into a table? (Choose the most sensible and appropriate answer)
- SELECT 절 사용
- INSERT 절에 각 값을 수동으로 입력
- SET 연산자 사용
- 해당 사항 없음
Answer: A. SELECT 절을 사용하는 것은 테이블에 행을 삽입하는 가장 일반적인 기술입니다. 각 열의 값을 수동으로 입력하는 노력을 줄여줍니다.
18.Which of the following commands is used to change the rows that already exist in a table?
- INSERT
- UNION
- UPDATE
- SELECT
Answer: C. UPDATE는 테이블의 열 값을 수정하는 데 사용되는 DML 문입니다.
19.What is true about the UPDATE command?
- 한 번에 하나의 행만 업데이트 할 수 있습니다.
- 한 번에 100 개의 행만 업데이트 할 수 있습니다.
- 한 번에 무제한 행을 대량으로 업데이트 할 수 있습니다.
- 해당 사항 없음
Answer: C. UPDATE는 WHERE 절 조건에 따라 한 번에 하나 이상의 행에있는 여러 행을 업데이트 할 수 있습니다.
20.Which of the following clauses decides how many rows are to be updated?
- SELECT
- WHERE
- FROM
- 무엇보다도
Answer: B. UPDATE 문은 WHERE 절을 사용하여 업데이트해야하는 행 집합을 캡처합니다.
21.What among the following is true about the UPDATE statement? (Choose the most appropriate answer)
- UPDATE는 하나의 테이블에서만 행을 업데이트 할 수 있습니다.
- UPDATE는 여러 테이블의 행을 업데이트 할 수 있습니다.
- 단일 UPDATE 명령은 여러 테이블의 행에 영향을 줄 수 없습니다.
- 해당 사항 없음
Answer: A, C. UPDATE 문은 여러 테이블이 아닌 한 테이블의 행에만 영향을줍니다.
Consider the following data set from the EMPLOYEES table and its structure. Answer questions 22 to 24 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)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE CLERK
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
22. You need to change the JOB_ID for Bruce (Employee Id 7389) to 'ACCOUNTANT'. Which of the following statements will you fire?
UPDATE employees SET job_id = 'ACCOUNTANT' WHERE employee_id = 7389;
INSERT INTO EMPLOYEES (employee_id , first_name , job_id ) VALUES (5100,'BRUCE', 'ACCOUNTANT');
UPDATE employees SET job_id = 'ACCOUNTANT' WHERE job_id = 'CLERK';
UPDATE employees SET job_id = 'ACCOUNTANT';
Answer: A. 옵션 B는 모든 사무원의 작업 코드를 ACCOUNTANT로 수정하기 때문에 실패합니다. 옵션 C는 테이블의 모든 직원에 대해 작업 코드를 ACCOUNTANT로 업데이트하기 때문에 잘못되었습니다.
Answer the following questions 23 and 24 based on the below actions -
위에 표시된 데이터 세트를 사용하여 EMPLOYEES 테이블에 다음 쿼리를 실행합니다.
UPDATE employees
Set job_id = NULL
Where employee_id = 51000;
데이터 세트는 다음과 같습니다. (EMPLOYEE_ID 열에 중복 값 제약이 있다고 가정)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
23. Suppose you fire an UPDATE statement to update Bruce's JOB_ID to 'SALESMAN' (with respect to the data set shown above). What will be the outcome of the query?
- Bruce의 작업 코드는 여전히 NULL입니다.
- Bruce의 작업 코드가 'SALESMAN'으로 수정됩니다.
- ORA 오류
- 조치 없음
Answer: B. UPDATE는 NULL 값에 새 값을 추가하여 NULL을 새 값으로 변경합니다.
24. You issue an UPDATE statement to update the employee id 7389 to 7900. You query the employee by its id '7389' before committing the transaction. What will be the outcome?
- 업데이트는 성공적으로 작동하지만 선택하면 7389가 표시됩니다.
- 업데이트는 성공적으로 작동하지만 선택하면 기록이 표시되지 않습니다.
- EMPLOYEE_ID에 대한 제한으로 인해 업데이트 할 수 없습니다.
- 성공적으로 업데이트되지만 EMPLOYEE_ID 7389의 모든 값은 NULL이됩니다.
Answer: B. 세션의 쿼리는 진행중인 트랜잭션과 일치합니다. 동일한 쿼리가 다른 세션에서 실행 된 경우 첫 번째 세션의 활성 트랜잭션이 아직 커밋되지 않았기 때문에 ID가 7389 인 직원 레코드가 표시되었을 것입니다.
25. What among the following is a typical use of an UPDATE statement? (Select the most appropriate answer)
- 행을 검색하고 해당 행의 하나 이상의 열을 업데이트하려면
- 일부 열의 모든 행을 수정하려면
- 테이블의 모든 열에 대한 모든 행을 수정하려면
- 해당 사항 없음
Answer: A. 하지만 UPDATE 문은 모든 행의 모든 열 값을 수정할 수 있지만 일반적으로 행을 선택하고 하나 이상의 열을 업데이트하는 데 사용됩니다.
26. Which of the following practices appropriately describe for selecting which row set to update using the UPDATE statement?
- 일부 행을 업데이트해야하는 경우 PRIMARY KEY 제약 조건을 사용할 수 있습니다.
- 모든 행을 업데이트해야하는 경우 WHERE 절을 고려할 수 있습니다.
- 행 집합을 업데이트하려면 WHERE를 사용하고 테이블의 모든 행을 업데이트하려면 테이블에 PRIMARY KEY 제약 조건을 지정합니다.
- 해당 사항 없음
Answer: C.
27. Which of the following columns in a table are not usually updated?
- 테이블의 LONG 유형 열
- 테이블의 LOB 컬럼
- 다른 테이블에서 외래 키 참조 역할도하는 기본 키 열
- 무엇보다도
Answer: C. 일반적으로 다른 테이블에서 외래 키 참조 역할을하는 기본 키 열은 업데이트하면 안됩니다. 일반적으로 권장되지 않는 제약 조건을 연기하여 업데이트 할 수 있습니다.
Consider the following data set and structure of the EMPLOYEES table and answer the questions 28 and 29 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)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE NULL
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
28. You issue an UPDATE statement as follows:
UPDATE employees
SET job_id = NULL;
위 진술의 결과는 무엇입니까?
- 데이터 세트의 첫 번째 행이 NULL로 업데이트됩니다.
- 첫 번째 행의 세 번째 열이 NULL로 업데이트됩니다.
- 모든 행의 세 번째 열이 NULL로 업데이트됩니다.
- 그리고 ORA 오류가 발생합니다.
Answer: C. WHERE 절이없는 UPDATE 문은 테이블의 모든 행을 업데이트합니다.
29. You issue an UPDATE statement as follows:
UPDATE employees
SET employee_id = NULL;
WHERE job_id = 'CLERK';
위 진술의 결과는 무엇입니까? (여기서 EMPLOYEE_ID 열은 제약 조건을 넣어 필수로 표시됩니다.)
- 데이터 세트의 첫 번째 열이 NULL로 업데이트됩니다.
- 첫 번째 행의 세 번째 열이 NULL로 업데이트됩니다.
- 모든 행의 세 번째 열이 NULL로 업데이트됩니다.
- 그리고 ORA 오류가 발생합니다.
Answer: D. 값을 업데이트하는 동안 열에 대한 제약 조건을 준수해야합니다. 주어진 UPDATE 문에서 EMPLOYEE_ID 열이 EMPLOYEES 테이블의 기본 키이므로 NULL이 될 수 없기 때문에 오류가 발생합니다.
30. Which of the following commands can be used to remove existing records from a table?
- UPDATE
- INSERT
- MINUS
- DELETE
Answer: D. DELETE는 선택적으로 조건을 기반으로 할 수있는 테이블에서 레코드를 제거하는 데 사용됩니다. DML 문이기 때문에 트랜잭션의 일부입니다.
31. What among the following is true about the DELETE statement?
- DELETE 문은 WHERE 절과 함께 제공되어야합니다.
- DELETE 문으로 WHERE 절을 작성하는 것은 필수가 아닙니다.
- DELETE는 한 번에 여러 테이블에서 데이터를 제거 할 수 있습니다.
- 해당 사항 없음
Answer: B. WHERE 절 술어는 DELETE 문에서 선택 사항입니다. WHERE 절을 생략하면 테이블의 모든 행이 삭제됩니다.
32.What among the following happens when we issue a DELETE statement on a table? (Choose the most appropriate answer)
- 사용자에게 요청 된 행을 삭제할 것인지 묻는 메시지가 나타납니다.
- DELETE 문에 지정된 조건을 따르는 행은 즉시 제거됩니다.
- 요청 된 행은 프롬프트없이 즉시 제거됩니다.
- 해당 사항 없음
Answer: C. 활성 또는 새 트랜잭션의 일부로 테이블의 행이 삭제됩니다.
33.Consider the following data set from the EMPLOYEES table and its structure:
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)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
employee_id가 51001 인 행의 JOB_ID 열에서 데이터를 삭제해야합니다. 다음 중 올바른 쿼리는 무엇입니까?
UPDATE employees SET job_id = NULL WHERE employee_id = 51001;
DELETE job_id FROM employees WHERE employee_id = 51001;
DELETE FROM employees;
- 해당 사항 없음
Answer: D. DELETE 문을 사용하여 특정 행에 대한 특정 열 값을 삭제할 수 없습니다. 주어진 조건에 따라 전체 행이 삭제됩니다. 열에서 원하지 않는 값을 NULL로 업데이트 할 수 있습니다. 옵션 'A'가 가깝지만 질문의 맥락에서 정확하지 않습니다.
34. What is the difference between the UPSERT and MERGE statements?
- 다른 점이 없다
- UPSERT는 더 이상 사용되지 않는 MERGE 문에 채택 된 최신 용어입니다.
- UPSERT는 MERGE가 할 수없는 삭제 작업을 수행 할 수 있습니다.
- MERGE는 INSERT, UPDATE 및 DELETE를 수행하고 UPSERT는 UPDATE 및 INSERT 만 수행합니다.
Answer: D. UPSERT는 쓸모없는 문장이며 MERGE는 새로운 기능을 대신했습니다.
35. What is the difference between the MERGE command and the commands INSERT, UPDATE and DELETE?
- MERGE 문은 각 작업 (INSERT, UPDATE, DELETE)이 개별적으로 수행되는 것보다 더 많은 시간을 소비합니다.
- MERGE는 Oracle 10g 이후 더 이상 사용되지 않습니다.
- MERGE는 테이블에서 세 가지 작업을 모두 수행 할 수있는 반면 INSERT, UPDATE 및 DELETE는 한 번에 하나의 작업을 수행합니다.
- 위의 어느 것도 없습니다.
Answer: C. MERGE 문은 테이블의 세 작업을 단일 문에 포함 할 수 있으며 INSERT, UPDATE 및 DELETE는 한 번에 하나의 작업을 수행합니다.
36. Which of the following objects can be the data source in a MERGE statement?
- 테이블 만
- 하위 쿼리 만
- 테이블 또는 하위 쿼리
- A 또는 B 모두
Answer: C. MERGE는 테이블 또는 하위 쿼리와 잘 작동합니다.
37. What among the following is a TRUNCATE statement equivalent to? (Choose the most suitable answer)
- DELETE 문으로
- UPDATE 문에
- WHERE 절이없는 DELETE 문
- 해당 사항 없음
Answer: C. TRUNCATE는 하나의 명령에서 모든 행을 삭제합니다.
38.Which of the following situations indicate that a DML operation has taken place?
- 테이블에 새 행이 추가되는 경우
- 두 쿼리가 결합 된 경우
- 테이블이 잘리는 경우
- 해당 사항 없음
Answer: A. 테이블의 기존 행이 테이블에서 삽입, 수정 또는 제거 될 때 DML 문을 통해 수행됩니다.
39.Which of the following best defines a transaction?
- 트랜잭션은 데이터베이스 스키마의 DDL 문으로 구성됩니다.
- 트랜잭션은 데이터베이스 세션에서 COMMIT 또는 ROLLBACK으로 구성됩니다.
- 트랜잭션은 데이터베이스 세션에서 논리적 작업 단위를 형성하는 DML 문 모음 또는 DDL 또는 DCL 또는 TCL 문으로 구성됩니다.
- 트랜잭션은 데이터베이스의 서로 다른 세션에있는 DML 및 DDL 문 모음으로 구성됩니다.
Answer: C. 데이터베이스 트랜잭션은 데이터의 일관된 변경을 구성하는 하나 이상의 DML 문, DDL 문 또는 DCL 명령 (GRANT 또는 REVOKE)으로 구성됩니다. 첫 번째 DML 문으로 시작하고 DCL 또는 DDL 또는 TCL (COMMIT 또는 ROLLBACK) 명령으로 끝납니다. DDL 및 DCL 명령에는 자동 커밋 기능이 있습니다.
40. What does a collection of DML statements that form a logical unit work known as?
- ACID 속성
- UNION
- UNION ALL
- Transaction
Answer: D.
41.What happens when a DML statement in an active transaction encounters an error on execution?
- 전체 트랜잭션이 롤백됩니다.
- 트랜잭션의 DML은 상호 배타적이므로 실행을 계속할 수 있습니다.
- 트랜잭션의 다른 DML이 중단되고 오류가 해결 될 때까지 대기합니다.
- 해당 사항 없음
Answer: A. 활성 트랜잭션의 DML 문 중 하나에 오류가 발생하면 전체 트랜잭션이 롤백됩니다.
42.What is true about the keyword VALUES in INSERT statements?
- VALUES는 INSERT 중에 한 번에 여러 행을 추가 할 수 있습니다.
- VALUES는 INSERT 중에 한 번에 100 개의 행만 추가 할 수 있습니다.
- INSERT 키워드를 사용하는 경우 VALUES를 사용해야합니다.
- VALUES는 한 번에 하나의 행만 추가합니다.
Answer: D. VALUES 키워드는 컬럼 값이 INSERT 문에 명시 적으로 지정된 경우에만 사용됩니다.
Consider the following statement and the table structure. Answer the questions 43 to 45 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)
INSERT INTO departments (department_id , department_name , manager_id, location_id )
VALUES (100, 'Human Resources', 121, 1000);
43. How many rows will be inserted by the above statement?
- 0
- 2
- 3
- 1
Answer: D. 키워드 VALUES를 사용하면 한 번에 한 행만 삽입합니다.
44. In which order the values will get inserted with respect to the above INSERT statement?
- Location_id, manager_id, department_name, department_id
- 부서 _ID, 부서 _ 이름, 관리자 _ID, 위치 _ID
- 부서 _ID, 관리자 _ID, 부서 _ 이름, 위치 _ID
- department_id, department_name, location_id, manager_id
Answer: B. 열이 INSERT 절에 언급 된 경우 VALUES 키워드는 동일한 순서로 값을 포함해야합니다.
45. Suppose the above given statement is modified as below:
INSERT INTO departments VALUES (100, 'Human Resources', 121, 1000);
이 수정의 결과는 무엇입니까? DEPARTMENTS 테이블에 department_id, DEPARTMENT_NAME, MANAGER_ID 및 LOCATION_ID라는 네 개의 열이 있다고 가정합니다.
- 열 값이 테이블의 열과 동일한 순서로 제공된다는 가정하에 부서 테이블의 모든 열에 값을 삽입합니다.
- 열 이름이 명시 적으로 언급되지 않았기 때문에 ORA 오류가 발생합니다.
- INSERT에서 VALUES 절이 잘못 사용 되었기 때문에 ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: A. INSERT 문에 열 이름을 포함하는 것은 값이 테이블의 열 수와 순서를 준수해야하는 경우 선택 사항입니다.
46. What will be the outcome of the below INSERT statement? (Consider the table structure)
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)
INSERT INTO EMPLOYEES (employee_id , hire_date) VALUES (210,"21-JUN-2013");
- employee_id와 직원의 고용 날짜 만 삽입하고 다른 모든 열은 공백으로 둡니다.
- employee_id 만 삽입합니다.
- ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: C. 날짜 리터럴 형식에 오류가 있습니다. 큰 따옴표가 아니라 작은 따옴표로 묶어야합니다.
47.What will be the outcome of the below INSERT statement? (Consider the given table structure)
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)
INSERT INTO EMPLOYEES (employee_id , first_name) VALUES (210,"Bryan");
- employee_id와 Bryan의 이름 만 삽입하고 다른 모든 열은 공백으로 둡니다.
- 이름 만 삽입합니다.
- ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: C. 문자열 리터럴 형식에 오류가 있습니다. 큰 따옴표가 아니라 작은 따옴표로 묶어야합니다.
48. Suppose you need to insert the name O'Callaghan as the last name of the employees table. Which of the following queries will give you the required results? (Consider the given table structure)
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)
INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O'callahan');
INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O"callahan');
INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O' 'Callahan');
INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,"O'callahan");
Answer: C.
49. What will be the outcome of the below INSERT statement? (Consider the given table structure)
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)
INSERT INTO EMPLOYEES (employee_id , first_name) VALUES ("210",'Bryan');
- 숫자 값 오류가 발생합니다.
- employee_id와 Bryan의 이름 만 삽입하고 다른 모든 열은 NULL로 둡니다.
- employee_id 만 삽입합니다.
- 해당 사항 없음
Answer: A. 숫자 값은 따옴표로 묶어서는 안됩니다.
50. What will be the outcome of the below INSERT statement? (Consider the given table structure)
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)
INSERT INTO departments VALUES (200,'Accounts', NULL, NULL);
- ORA 오류가 발생합니다.
- 성공적으로 실행되지만 잘못된 값이 열에 삽입 될 수 있습니다.
- 성공적으로 실행됩니다.
- 해당 사항 없음
Answer: C. VALUES 절에서 NULL을 사용하여 열 값을 대신 채울 수 있습니다.
51. What will be the outcome of the below INSERT statement? (Assume there is a NOT NULL constraint on the department_id column and consider the table structure 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)
INSERT INTO departments VALUES (NULL, 'Accounts', NULL);
- ORA 오류가 발생합니다.
- 성공적으로 실행되지만 잘못된 결과가 나타납니다.
- 성공적으로 실행되지만 올바른 결과가 나타납니다.
- 해당 사항 없음
Answer: A. NULL이 아닌 열에는 NULL 값을 삽입 할 수 없습니다.
52. What will be the outcome of the below INSERT statement? (Assume there is a NOT NULL constraint on the department_id column and consider the given table structure)
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)
INSERT INTO departments VALUES (200, 34, NULL);
- 성공적으로 실행되지만 잘못된 결과가 나타납니다.
- ORA 오류가 발생합니다.
- 성공적으로 실행되지만 올바른 결과가 나타납니다.
- 해당 사항 없음
Answer: B. 값의 데이터 유형이 테이블에있는 열의 데이터 유형과 일치하지 않습니다.
53. Which of the following commands is used to save the changed data in a table permanently?
- ROLLBACK
- COMMIT
- INSERT
- UPDATE
Answer: B. TCL 명령 COMMIT는 보류중인 모든 데이터 변경 사항을 테이블에서 영구적으로 만들어 세션에서 현재 활성 트랜잭션을 종료하는 데 사용됩니다.
54. Which of the following commands allows undoing the changed data?
- ROLLBACK
- COMMIT
- INSERT
- UPDATE
Answer: A. TCL 명령 ROLLBACK은 보류중인 모든 데이터 변경 사항을 삭제하여 세션에서 현재 활성 트랜잭션을 종료하는 데 사용됩니다.
55. Which of the following commands allows enabling markers in an active transaction?
- ROLLBACK
- COMMIT
- SAVEPOINT
- 해당 사항 없음
Answer: C. SAVEPOINT는 트랜잭션을 더 작은 섹션으로 나누는 트랜잭션의 지점을 표시합니다.
56. Which of the following commands prevents other users from making changes to a table?
- ROLLBACK
- COMMIT
- 잠금 테이블
- SAVEPOINT
Answer: C.
57. What is true about an INSERT statement which tries to insert values into a virtual column? (Choose the most appropriate answer)
- 가상 열에 값을 삽입 할 수 없습니다.
- 값을 삽입 할 수 있습니다.
- ORA 오류가 발생합니다.
- 무엇보다도
Answer: A. 가상 컬럼은 컬럼 스펙에 정의 된 파생 표현식을 기반으로 항상 자동 생성되는 컬럼입니다. 이 값은 사용자가 명시 적으로 삽입 할 수 없습니다.
58.Which of the following commands allows the user to insert multiple rows with a single statement?
- INSERT
- 모두 삽입
- UNION ALL
- 해당 사항 없음
Answer: B. INSERT ALL을 사용하여 대량 삽입 작업을 수행 할 수 있습니다.
59. Which of the following is the syntax for inserting rows through a sub-query?
INSERT INTO tablename [{column_name,..}] subquery;
INSERT INTO tablename VALUES [{column_name,..}] subquery;
- A 및 B 둘
- 해당 사항 없음
Answer: A.
Consider the following exhibit of the EMPLOYEES table and answer the questions 60 to 63 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)
60. Which of the following queries will execute successfully?
UPDATE employees SET salary = salary + 1000 WHERE to_char (hire_date, 'YYYY') > '2006';
UPDATE employees SET salary = salary + 1000 WHERE to_date (hire_date, 'YYYY') > '2006';
UPDATE employees SET salary = salary + 1000 WHERE hire_date > to_date (substr ('01-jan-200',8));
UPDATE employees SET salary = salary + 1000 WHERE hire_date in (to_date ('JUN 01 11', to_date ('JUL 01 11'));
Answer: A.
61.Due to structural reorganization in the organization, you are asked to update department IDs for all the employees to NULL before the final decision is made public. Only those records should be updated which have the JOB_ID as NULL. Which of the following queries will work?
UPDATE employees SET department_id = NULL Where job_id = NULL;
UPDATE employees SET department_id = NULL Where job_id = TO_NUMBER(NULL);
UPDATE employees SET department_id = NULL Where job_id IS NULL;
UPDATE employees SET department_id = TO_NUMBER (' ', 9999) Where job_id = TO_NUMBER(NULL);
Answer: C. IS NULL 연산자를 사용하여 열 값이 null인지 확인합니다.
62.You need to add a basic employee data into EMPLOYEES table. The basic data contains the last name as 'Bond' and department ID as 300. Which of the following statements will give the correct results?
INSERT INTO employees (employee_id , last_name, department_id ) (100,'Bond', (select department_id from departments where department_id = 300));
INSERT INTO employees (employee_id , last_name, department_id ) VALUES (100,'Bond', (select department_id from departments where department_id = 300));
INSERT INTO employees (employee_id , last_name, department_id ) VALUES ('100','Bond',300);
- 해당 사항 없음
Answer: B, C. 하위 쿼리는 사용되는 열과 일치하거나 호환되는 데이터 유형의 스칼라 값을 반환하는 경우 INSERT 문에서 작동합니다.
63. You fire the following query:
DELETE FROM EMPLOYEES;
세션의 EMPLOYEES 테이블에 활성 트랜잭션이 없다고 가정 할 때 다음 중 참인 것은 무엇입니까?
- 테이블의 모든 행과 구조를 제거합니다.
- 롤백 할 수있는 모든 행을 제거합니다.
- 모든 행을 영구적으로 제거합니다.
- 해당 사항 없음
Answer: B. DML 문이므로 DELETE 작업으로 인한 데이터 변경은 세션에서 COMMIT가 실행 된 후에 만 영구적으로 적용됩니다.
64.Consider the structure of the COUNTRY table as shown:
SQL> desc countries
Name Null? Type
----------------------- -------- ----------------
COUNTRY_ID NOT NULL CHAR(2)
COUNTRY_NAME VARCHAR2(40)
REGION_ID NUMBER
세션에서 다음 명령문을 발행합니다.
INSERT INTO COUNTRIES (1, 'Whales')
/
INSERT INTO COUNTRIES (2, 'England')
/
SAVEPOINT A;
UPDATE COUNTRIES
SET country_id= 100 where country_id= 1
/
SAVEPOINT B;
DELETE FROM COUNTRIES where country_id= 2
/
COMMIT
/
DELETE FROM COUNTRIES where country_id= 100
/
사용자 세션에 대해 ROLLBACK TO SAVEPOINT 명령이 실행되면 어떻게됩니까?
- 롤백은 오류를 생성합니다.
- DELETE 문만 롤백됩니다.
- 롤백 된 SQL 문이 없습니다.
- 해당 사항 없음
Answer: A, C. A와 B라는 두 개의 세이브 포인트가 있고 ROLLBACK 명령이 실제 세이브 포인트 표시를 지정하므로 Oracle은 오류를 발생시킵니다.
65.If a user issues a DML command and exits the SQL Developer abruptly without a COMMIT or ROLLBACK, what will be the outcome? (Assume the session is not auto commit)
- 자동 커밋
- 자동 롤백
- 트랜잭션을 종료하기위한 COMMIT 또는 ROLLBACK 일 수 있습니다.
- 해당 사항 없음
Answer: B. 시스템 장애로 인해 트랜잭션이 중단되면 전체 트랜잭션이 자동으로 롤백됩니다.
66. Which of the following commands / statements would end a transaction?
- COMMIT
- SELECT
- SAVEPOINT
- CREATE
Answer: A, D. COMMIT 또는 ROLLBACK과 같은 TCL 명령 외에도 DDL 명령 및 DCL 명령은 자동 커밋 기능을 가지고 있습니다. DDL 문이 동일한 세션에서 실행되면 활성 트랜잭션이 커밋됩니다.
67.When does a transaction complete?
- ROLLBACK이 실행될 때
- COMMIT가 실행될 때
- TRUNCATE가 실행될 때
- 무엇보다도
Answer: D. TCL, DCL 또는 DDL 명령이 세션에서 실행되면 트랜잭션이 완료됩니다.
68. Examine the given table structures and consider 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)
INSERT INTO EMPLOYEES (department_id ) VALUES
(select department_id FROM departments);
위 쿼리의 결과는 무엇입니까?
- EMPLOYEES 테이블과 departments 테이블의 열이 일치하지 않습니다.
- 하위 쿼리에서 사용하려면 WHERE 절이 필수입니다.
- VALUES 키워드는 하위 쿼리를 사용할 때 INSERT 절과 함께 사용할 수 없습니다.
- 해당 사항 없음
Answer: C. VALUES 키워드를 잘못 사용했습니다. 테이블에 삽입해야하는 열 데이터가있는 경우에만 사용해야합니다.
69.Examine the given table structure and consider 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 job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
UPDATE (select employee_id , job_id from employees)
SET hire_date = '01-JAN-13'
WHERE employee_id = (select employee_id FROM job_history);
다음 중 주어진 쿼리와 관련하여 참인 것은 무엇입니까?
- 단일 update 문에서 두 개의 테이블을 사용할 수 없으므로 실행되지 않습니다.
- UPDATE가 하위 쿼리를 사용할 수 없으므로 실행되지 않습니다.
- 지정된 열에 대한 제한으로 실행됩니다.
- WHERE 절에서 하위 쿼리가 사용되므로 실행되지 않습니다.
Answer: C.
70.What happens when a transaction is committed?
- 트랜잭션 중 변경 사항은 특정 사용자 세션에 대해 저장됩니다.
- 거래 중 변경된 내용은 삭제됩니다.
- 트랜잭션이 DDL이면 커밋이 작동하지 않습니다.
- 해당 사항 없음
Answer: D. 트랜잭션을 커밋하면 보류중인 데이터 변경 사항이 데이터베이스에 영구적으로 저장됩니다.
71. Which of the following reasons will the best one on the usage of string?
- 하위 쿼리 사용
- 구문 오류
- 액세스 권한
- 제약 위반
Answer: C, B, D. 존재하지 않는 개체 / 열에 대한 참조, 공간 문제는 다른 이유 일 수 있습니다.
72. What happens when an INSERT statement tries to insert records in an old table?
- 모든 열은 NULL 값을 얻습니다.
- 동일한 이름의 새 테이블이 자동으로 생성되고 값이 삽입됩니다.
- INSERT가 작동하지 않고 ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: C.
73. A user named 'Jonathan Adams' is able to SELECT columns from the EMPLOYEES table but he is unable to insert records into EMPLOYEES. What can be the reason?
- Jonathan이 INSERT 문을 지원하지 않는 데이터베이스에 연결되어 있습니다.
- INSERT 문은 EMPLOYEES 테이블에 적용 할 수 없습니다.
- Jonathan은 SELECT에 대한 액세스 권한이 있지만 EMPLOYEES 테이블에 INSERT INTO에 대한 액세스 권한이 없습니다.
- 해당 사항 없음
Answer: C. 사용자는 자신의 책임에 따라 테이블 액세스를 즐길 수 있습니다. 하나는 테이블에 대한 읽기 액세스 만 가질 수 있고 다른 하나는 읽기 및 쓰기 액세스를 즐길 수 있습니다.
74. Suppose 1 million rows are to be inserted into the AUDIT table. An INSERT transaction runs successfully for the first 1000 rows and an ORA error is thrown 'Constraint violated'. What will happen to the values inserted in the first 1000 rows?
- 그대로 유지됩니다.
- 모두 삭제됩니다.
- 모두 롤백됩니다.
- 해당 사항 없음
Answer: C. 트랜잭션 중 DML 문에 오류가 발생하면 전체 트랜잭션이 롤백됩니다.
Examine the table structure and consider the following query and answer the questions 75, 76 and 77 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)
INSERT INTO departments values (15, NULL);
75. What will be the outcome of this statement?
- department_id = 15이고 다른 모든 값은 NULL 인 행을 삽입합니다.
- 성공적으로 실행되지만 테이블에 0 개의 행을 삽입합니다.
- 아니오로 ORA 오류가 발생합니다. 열과 값이 일치하지 않습니다.
- 해당 사항 없음
Answer: C. DEPARTMENTS 테이블에는 4 개의 열이 있지만 INSERT 문은 열을 언급하지 않고 두 개의 열에 대해서만 값을 제공합니다. 따라서 ORA 오류가 발생합니다.
76. What is true about the above INSERT statement?
- INSERT 문에 열이 언급되지 않은 경우 값은 열에 위치에 삽입됩니다.
- INSERT 문 다음에 열을 언급해야합니다.
- A 및 B 둘
- 해당 사항 없음
Answer: A. 열이 INSERT 문에 지정되지 않은 경우 Oracle은 각 값을 테이블의 열에 순차적으로 위치 적으로 매핑합니다.
77. With respect to the statement given above, what will happen if the table is altered to add a new column?
- 성명은 여전히 작동합니다.
- 번호가 일치하지 않으므로 문 실행시 오류가 발생합니다. 열 및 값
- 변경 사항이 없으며 이전과 같이 명령문이 실행됩니다.
- 해당 사항 없음
Answer: B. 열이 이전에 지정되지 않았기 때문에 문제는 여전히 존재합니다. 열-값 매핑이 일치하지 않으면 ORA 오류가 발생합니다.
Examine the table structure given below and consider the following queries and answer the questions 78 and 79 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)
Query 1:
INSERT INTO employees (employee_id , last_name, hire_date)
VALUES (100, 'ADAMS','21-DEC-12');
Query 2:
INSERT INTO employees (employee_id , last_name, hire_date)
VALUES (100, upper('ADAMS'),to_date('21-DEC-12','DD-MON-YY'));
78. Which of the above two queries is better?
- 둘 다 더 낫다
- 쿼리 1 만 더 좋습니다.
- 쿼리 2 만 더 좋습니다.
- 올바른 쿼리가 없습니다.
Answer: C. Query-2는 날짜 값을 문자열이 아닌 날짜로 삽입하기 때문에 더 좋습니다. Oracle은 날짜로 지정된 문자열 리터럴의 암시 적 변환을 수행하지만 권장하지는 않습니다.
79. Which of the following queries is equivalent of the query 2 given above?
INSERT INTO employees (employee_id , last_name, hire_date) VALUES (101-1, upper('ADAMS'),to_date('21-DEC-12','DD-MON-YY'));
INSERT INTO employees (employee_id , last_name, hire_date) VALUES (99+1, upper('ADAMS'),to_date('22-DEC-12','DD-MON-YY') +1 );
INSERT INTO employees (employee_id , last_name, hire_date) VALUES (100, upper('ADAMS'),to_date('21-DEC-12','DD-MON-YY') - 1);
INSERT INTO employees (employee_id , last_name, hire_date) VALUES (100, upper('ADAMS'),to_date('28-DEC-12','DD-MON-YY')-7 );
Answer: A, C, D. 산술 연산 / 함수를 사용하여 위와 같이 값을 삽입 할 수 있습니다.
80. You need to copy the data from one table to another table. Which of the following methods can be used?
- COPY 명령을 사용할 수 있습니다.
- INSERT 명령을 사용할 수 있습니다.
- UPDATE 명령을 사용할 수 있습니다.
- 해당 사항 없음
Answer: B. 직접 경로 작업 INSERT-AS-SELECT (IAS)는 한 테이블에서 다른 테이블로 데이터를 복사하는 데 가장 일반적으로 사용되는 방법입니다.
81.Which of the following statements will copy data from the JOB_HISTORY table to the JOB_HISTORY_ARCHIVE table? (Consider the table structure as given)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
INSERT INTO job_history values (select * from job_history);
INSERT INTO JOB_HISTORY_ARCHIVE values (select * from job_history_archive);
INSERT INTO JOB_HISTORY_ARCHIVE select * from job_history;
- 해당 사항 없음
Answer: C. 'C'옵션은 IAS (INSERT-AS-SELECT) 방법의 사용법을 올바르게 표시합니다.
Examine the given table structure. Consider the following query and answer the questions 82 and 83 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)
INSERT ALL
WHEN job_id = 'SA_REP' then
INTO employees (employee_id , department_id , salary, hire_date)
VALUES (employee_id , 10, salary, hire_date)
WHEN job_id <> 'SA_REP' then
INTO employees (employee_id , department_id , salary, hire_date)
VALUES (employee_id , 20, salary, hire_date)
SELECT employee_id , department_id , job_id, salary, commission_pct , hire_date
FROM employees
WHERE hire_date > sysdate - 30;
82. Interpret the output of the above INSERT statement.
- 오류가 발생했습니다.
- sysdate 한 달 전에 고용 된 모든 직원의 기록을 삽입합니다.
- 부서 10의 영업 담당자 인 모든 직원에 대한 레코드가 삽입됩니다.
- 해당 사항 없음
Answer: B, C. INSERT ALL은 대상 테이블에 조건부 삽입을 할 수 있습니다.
83. Which employees' data will be inserted in the department 20?
- 영업 담당자
- Accountants
- A 또는 B 모두
- 해당 사항 없음
Answer: B. INSERT ALL 문에 따라 job_id가 'Sales Representative'가 아닌 직원의 세부 정보입니다.
84. What will be the outcome of 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)
INSERT INTO employees (employee_id , salary) VALUES (&employee_id , &salary);
COMMIT;
- DML 문에서 대체 변수를 사용할 수 없으므로 구문 오류
- 사용자에게 직원 ID와 급여를 입력하라는 메시지가 표시되지만 대체 변수는 테이블에 데이터를 삽입 할 수 없습니다.
- 사용자에게 직원 ID를 입력하라는 메시지가 표시되고 급여 및 기록이 EMPLOYEES 테이블에 성공적으로 생성됩니다.
- 해당 사항 없음
Answer: C. 대체 변수는 DML 문과 잘 작동합니다.
85. Evaluate the following SQL statements that are executed in a user session in the specified order:
CREATE SEQUENCE id_seq;
SELECT id_seq.nextval
FROM dual;
INSERT INTO employees (employee_id ,first_name,job_id )
VALUES (ord_seq.CURRVAL, 'Steyn','Trainee');
UPDATE employees
SET employee_id = id_seq.NEXTVAL
WHERE first_name = 'Steyn'
AND job_id ='Trainee';
위 진술의 결과는 무엇입니까?
- 시퀀스의 최소값과 최대 값이 지정되지 않았기 때문에 CREATE SEQUENCE 명령에서 오류가 발생합니다.
- 모든 명령문이 성공적으로 실행되고 employee_id 열에는 직원 STEYN에 대한 값 2가 포함됩니다.
- 시퀀스의 시작 값과 증분 값이 지정되지 않았기 때문에 CREATE SEQUENCE 명령이 실행되지 않습니다.
- 모든 명령문이 성공적으로 실행되고 employee_id 열은 기본 CACHE 값이 20이기 때문에 직원 STEYN에 대해 20 값을 갖게됩니다.
Answer: B.
86. What is the restriction on the sub-query used in the UPDATE statement?
- 하위 쿼리는 다중 행 하위 쿼리 여야합니다.
- 하위 쿼리는 단일 행 하위 쿼리 여야합니다.
- 제한이 없습니다
- 하위 쿼리는 단일 행 또는 다중 행 하위 쿼리 일 수 있습니다.
Answer: B. 하위 쿼리는 UPDATE 문에서 사용될 때 여러 행을 반환하지 않아야합니다.
Examine the given table structure and consider the query given below and answer the questions 87 and 88 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)
UPDATE employees
SET salary = (SELECT salary FROM employees WHERE employee_id =7382);
87. What will be the outcome of the above query?
- 실행시 ORA 오류가 발생합니다.
- 모든 직원의 급여는 직원 7382와 동일한 급여로 업데이트됩니다.
- 모든 직원의 급여가 NULL로 업데이트됩니다.
- 해당 사항 없음
Answer: B. 쿼리 결과를 사용하여 테이블의 열 값을 업데이트 할 수 있습니다.
88. Suppose if the employee 7382 doesn't exist in the EMPLOYEES table. What will be the outcome of the query?
- 쿼리 결과를 열로 업데이트 할 수 없기 때문에 실행시 ORA 오류가 발생합니다.
- 모든 직원의 급여가 NULL로 업데이트됩니다.
- 직원 7382가 존재하지 않기 때문에 ORA 예외 'NO_DATA_FOUND'가 발생합니다.
- 해당 사항 없음
Answer: B. UPDATE 문은 구문 오류를 제외하고는 예외를 발생시키지 않습니다.
Examine the given table structure and consider the query 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)
UPDATE employees
set salary = (select salary from employees where last_name = 'Adams');
89. What will be the outcome of the query?
- 성공적으로 실행됩니다.
- 테이블의 모든 행에는 동일한 급여가 있습니다.
- 실행시 ORA 오류 'TOO_MANY_ROWS'가 발생할 수 있습니다.
- 해당 사항 없음
Answer: C. 하위 쿼리는 오류를 일으키는 두 개 이상의 행을 반환 할 수 있습니다.
90. What changes in the above query will make sure there are no errors caused?
- MAX, MIN 또는 AVG와 같은 단일 행 함수를 사용하여 다중 행 결과를 스칼라 결과로 줄입니다.
- SALARY 열에 기본 키 제약 조건 추가
- 변경이 필요하지 않습니다.
- 해당 사항 없음
Answer: A.
Examine the given table structure and consider the following query and answer the questions 91 and 92 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)
UPDATE employees
SET salary = (select max (salary) from employees where last_name = 'Adams');
91. What will be the outcome of the query given above?
- Adam이라는 직원의 급여와 동일한 모든 직원의 급여를 업데이트합니다.
- 성이 'Adam'인 모든 직원의 평균 급여와 동일한 급여를 모든 직원의 급여로 업데이트합니다.
- 0 개의 행을 업데이트합니다.
- 한 행만 업데이트합니다.
Answer: B. 산술 함수 MAX 또는 MIN을 하위 쿼리와 함께 사용하여 스칼라 값을 가져오고 오류를 방지 할 수 있습니다.
92. Assume that the sub-query above is replaced with the following:
SELECT distinct salary from employees where last_name = 'Adam';
위에 주어진 기본 쿼리의 결과는 무엇입니까?
- 잘못된 결과를 제공하면서 성공적으로 실행됩니다.
- 올바른 결과를 제공하면서 성공적으로 실행됩니다.
- ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: C. 성이 '아담'인 사람이 많기 때문에 서로 다른 급여가 많기 때문에 오류가 발생합니다.
Examine the given table structure and consider the following query and answer the questions 93 and 94 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)
UPDATE employees
SET salary = 50000;
WHERE job_id in (select job_id from job_history where department_id = 10);
93. What will the above statement do? (Choose the most appropriate answer)
- 모든 직원의 모든 급여를 50000으로 업데이트합니다.
- 부서 10에있는 모든 직원의 모든 급여를 업데이트합니다.
- 부서 10에있는 것과 유사한 작업 ID 중 하나를 가진 모든 직원의 급여를 업데이트합니다.
- 해당 사항 없음
Answer: C.
94. What will happen if the WHERE clause given above is replaced with the following?
WHERE job_id = (select job_id from job_history where department_id = 10);
- 잘못된 결과로 성공적으로 실행됩니다.
- 올바른 결과로 성공적으로 실행됩니다.
- ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: C. 등호는 오류를 발생시킵니다.
Examine the given table structure and consider the following statement. Answer the questions 95 to 97 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)
DELETE FROM employees where last_name = 'A%';
COMMIT;
95. What will be the outcome of the query given above?
- 성공적으로 실행되지만 행이 삭제되지 않습니다.
- last_name이 "A"로 시작하는 모든 직원이 삭제됩니다.
- DELETE 문은 WHERE 조건자를 가질 수 없기 때문에 ORA 오류
- 직원 테이블의 모든 행이 삭제됩니다.
Answer: A. DELETE 문은 WHERE 절 술어를 가질 수 있습니다. 조건에 따라 레코드가 테이블에서 제거됩니다.
96. Consider the following statement:
DELETE FROM employees where employee_id IS NULL and job_id = NULL;
COMMIT;
employee_id 열에 NOT NULL 제약 조건이 있다고 가정하면 위 쿼리의 결과는 무엇입니까?
- 잘못된 WHERE 술어로 인해 ORA 오류가 발생합니다.
- 성공적으로 실행되고 행이 삭제되지 않습니다.
- 여러 술어가 DELETE 문에서 작동 할 수 없기 때문에 ORA 오류가 발생합니다.
- 해당 사항 없음
Answer: B. 여러 조건자가 DML 문 UPDATE 및 DELETE에 적용될 수 있습니다.
97. Consider the following query:
DELETE FROM employees where department_id = &deptID;
COMMIT;
위의 명령문이 실행되면 어떻게됩니까?
- DML 문은 대체 변수를 사용할 수 없기 때문에 오류가 발생합니다.
- 사용자로부터 부서 ID를 삭제하고 주어진 부서 ID로 레코드를 삭제하라는 메시지가 표시됩니다.
- 부서 ID를 묻는 메시지가 표시되지만 트랜잭션을 커밋 할 수 없습니다.
- 해당 사항 없음
Answer: B. 대체 변수는 DML 문과 함께 사용할 수 있습니다.
98. All parts of a transaction should complete or none of them. Which property of ACID rule complies with the given statement?
- Atomicity
- Consistency
- Isolation
- Durability
Answer: A. ACID는 데이터베이스 트랜잭션의 기본 속성 인 원 자성, 일관성, 격리 및 내구성을 나타냅니다. 원자 성은 전체 일련의 작업이 완료되거나 중단되어야 함을 의미합니다. 일관성은 트랜잭션이 하나의 일관성있는 상태에서 다른 상태로 리소스를 가져가는 것을 의미합니다. 격리는 트랜잭션이 커밋 될 때까지 트랜잭션의 효과가 다른 트랜잭션에 표시되지 않음을 의미합니다. 내구성은 커밋 된 트랜잭션에 의한 변경 사항이 영구적이며 시스템 오류가 지속되어야 함을 의미합니다.
99. What does the principle of Durability in the ACID property state?
- 데이터베이스가 완료된 트랜잭션을 잃을 수 있음을 나타냅니다.
- 거래를 완료 할 수 없음을 나타냅니다.
- 트랜잭션이 완료되면 DB가이를 잃어 버릴 수 없음을 명시합니다.
- 해당 사항 없음
Answer: C.
100. An incomplete transaction should be invisible to all the other users. Which of the properties of the ACID state this?
- Isolation
- Consistency
- Atomicity
- Durability
Answer: A. "I"는 격리를 나타냅니다.
101. What does the principle of consistency states?
- 쿼리 결과가 쿼리 시작 시점의 DB 상태와 일치해야 함을 나타냅니다.
- 불완전한 거래는 다른 모든 사용자에게 보이지 않아야 함을 나타냅니다.
- 트랜잭션이 완료되면 DB가이를 잃어 버릴 수 없음을 명시합니다.
- 해당 사항 없음
Answer: A. ACID 속성의 "C"는 일관성을 나타냅니다.
102. What among the following best describes a Transaction?
- INSERT to COMMIT / ROLLBACK
- COMMIT / ROLLBACK 업데이트
- 커밋 / 롤백하려면 삭제
- INSERT / UPDATE / DELETE to COMMIT / ROLLBACK
Answer: D.
103. A user named "Jonathan" inserts data in the table EMPLOYEES. When will the other users be able to see the new data?
- Jonathan이 사용자에게 액세스 권한을 제공하는 경우
- Jonathan이 세션에서 ROLLBACK 문을 실행할 때
- Jonathan이 동일한 세션에서 COMMIT 문을 실행할 때
- Jonathan이 새 세션을 열고 COMMIT를 발행 할 때
Answer: C. 활성 트랜잭션은 동일한 세션에서 커밋되어야합니다.
104. What can be said about the nesting of transactions?
- 최대 2 단계의 중첩이 가능합니다.
- 최대 255 수준의 중첩이 가능합니다.
- 트랜잭션 중첩이 불가능합니다.
- 1 단계의 중첩 만 가능합니다.
Answer: C.
105. Which of the following reasons will terminate a transaction?
- DDL 문
- 클라이언트 종료
- 시스템 충돌
- 무엇보다도
Answer: D. DDL은 자동 커밋이며 진행중인 활성 트랜잭션을 종료합니다.