Управление вопросами данных

1.What does ACID mean with respect to relational database?

  1. Точность, согласованность, изоляция, база данных
  2. Точность, параллелизм, изоляция, долговечность
  3. Атомарность, последовательность, изоляция, долговечность
  4. Атомарность, параллелизм, изоляция, надежность

Answer: C. Все транзакции Oracle соответствуют основным свойствам транзакции базы данных, известным как свойства ACID. Атомарность утверждает, что все задачи транзакции выполнены или ни одна из них не выполняется. Частичных транзакций нет. Согласованность подразумевает, что транзакция переводит базу данных из одного согласованного состояния в другое согласованное состояние. Изоляция означает, что эффект от транзакции не виден другим транзакциям, пока транзакция не будет зафиксирована. Долговечность означает, что изменения, внесенные совершенными транзакциями, являются постоянными. После завершения транзакции база данных с помощью механизмов восстановления гарантирует, что изменения транзакции не будут потеряны.

2. What does the word DML stands for in Oracle SQL?

  1. Язык управления долговечностью
  2. Язык управления базами данных
  3. Язык манипулирования базой данных
  4. Ни один из вышеперечисленных

Answer: C. DML означает язык манипулирования данными.

3. Which of the following are DML commands in Oracle Database?

  1. SELECT
  2. ГРУППА ПО
  3. INTERSECT
  4. 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?

  1. INTERSECT
  2. INSERT
  3. SELECT
  4. MERGE

Answer: D. MERGE может выполнять действия INSERT и UPDATE в одном операторе Oracle.

5. What all operations can MERGE statement perform in SQL?

  1. INSERT
  2. DELETE
  3. ГРУППА ПО
  4. Ни один из вышеперечисленных

Answer: A, B. В некоторых условиях MERGE может также выполнять операцию DELETE вместе с INSERT и UPDATE.

6.Which of following commands is a DDL (Data Definition Language) command but is often considered along with DML commands?

  1. DELETE
  2. INSERT
  3. TRUNCATE
  4. Ни один из вышеперечисленных

Answer: C. TRUNCATE - это команда DDL. Он удаляет записи из таблицы без каких-либо условий. Это не часть текущей транзакции, и незафиксированная транзакция в сеансе фиксируется после выполнения TRUNCATE.

7.Which of the following commands manipulate data basically?

  1. MINUS
  2. UPDATE
  3. TRUNCATE
  4. Все вышеперечисленное

Answer: B, C. UPDATE - это оператор DML для изменения значения столбца в таблице. TRUNCATE манипулирует данными, безоговорочно удаляя их из таблицы.

8. Which of the following commands is used to populate table rows with data?

  1. DELETE
  2. INSERT
  3. SELECT
  4. UPDATE

Answer: B. Команда INSERT используется для вставки строк в таблицу.

9. What is true about the INSERT statement? (Choose the most appropriate answer)

  1. Он может вставлять данные в одну строку одной таблицы за раз
  2. Он может вставлять данные во многие строки одной таблицы за раз
  3. Он может вставлять данные во многие строки многих таблиц одновременно
  4. Все вышеперечисленное

Answer: C. Оператор INSERT может вставлять строку или набор строк в одну таблицу за раз.

10.What is true about the insertion of rows in tables?

  1. Строки можно вставлять случайным образом
  2. В таблицу можно вставить любое количество строк без каких-либо ограничений.
  3. Обычно строки вставляются в таблицу на основе определенных правил, известных как ограничения.
  4. Все вышеперечисленное

Answer: C. Ограничения - это бизнес-правила, налагаемые на столбцы, чтобы гарантировать поведение данных, поступающих в столбец. Эти ограничения проверяются для данных в процессе INSERT.

11. What is true about the INSERT statement in Oracle SQL? (Choose the most appropriate answer)

  1. Оператор INSERT может переопределить любое ограничение, наложенное на таблицу
  2. Оператор INSERT нельзя использовать в таблице, если ограничение уже наложено на таблицу
  3. Оператор INSERT можно использовать для таблицы, только если ограничение уже наложено на таблицу.
  4. Оператор INSERT никогда не может вставить строку, нарушающую ограничение.

Answer: D. Oracle вызывает исключение, если какие-либо данные, содержащиеся в операторе вставки, нарушают ограничение.

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 есть ограничение проверки повторяющихся значений, каков будет результат выполнения вышеуказанного оператора?

  1. Будет вставлена ​​еще одна строка с 5100 значениями BRUCE CLERK.
  2. Будет вставлена ​​еще одна строка со значениями 51002 BRUCE CLERK.
  3. Выдает ошибку ORA "Ограничение нарушено".
  4. Ни один из вышеперечисленных

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');

Что будет результатом этого утверждения?

  1. Будет вставлена ​​новая строка со значениями 51003 BRUCE CLERK.
  2. Это вызовет ошибку ORA, поскольку не может быть другого BRUCE, который является CLERK
  3. Выдает ошибку ORA "Ограничение нарушено".
  4. Ни один из вышеперечисленных

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);

Что будет результатом этого утверждения?

  1. Будет вставлена ​​новая строка со значениями 51003 BRUCE CLERK.
  2. Это вызовет ошибку ORA, поскольку не может быть другого BRUCE, который является CLERK
  3. Выдает ошибку ORA "Ограничение нарушено".
  4. Будет вставлена ​​новая строка со значениями 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?

  1. Пользователь не может интерактивно вставлять строки
  2. Можно написать запрос с переменными подстановки для интерактивной вставки строк пользователями.
  3. Когда пользователю предлагается вставить строки, вставка не работает и выдает ошибку ORA.
  4. Ни один из вышеперечисленных

Answer: B. Оператор INSERT может использовать переменную подстановки, чтобы предложить пользователю ввести значения во время выполнения. Он обеспечивает интерактивный способ вставки данных в таблицы.

16.Which of the following can be used to insert rows in tables?

  1. SELECT
  2. INSERT
  3. Sub-queries
  4. Все вышеперечисленное

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)

  1. Использование предложения SELECT
  2. Ввод каждого значения вручную в предложение INSERT
  3. Использование операторов SET
  4. Ни один из вышеперечисленных

Answer: A. Использование предложения SELECT является наиболее распространенным методом вставки строк в таблицы. Это снижает трудоемкость ручного ввода значений для каждого столбца.

18.Which of the following commands is used to change the rows that already exist in a table?

  1. INSERT
  2. UNION
  3. UPDATE
  4. SELECT

Answer: C. UPDATE - это оператор DML, который используется для изменения значений столбцов в таблице.

19.What is true about the UPDATE command?

  1. Он может обновлять только одну строку за раз
  2. Он может обновлять только 100 строк за раз
  3. Он может массово обновлять неограниченное количество строк за раз
  4. Ни один из вышеперечисленных

Answer: C. UPDATE может обновлять несколько строк в одной или нескольких строках одновременно на основе условий предложения WHERE.

20.Which of the following clauses decides how many rows are to be updated?

  1. SELECT
  2. WHERE
  3. FROM
  4. Все вышеперечисленное

Answer: B. Оператор UPDATE использует предложение WHERE для захвата набора строк, которые необходимо обновить.

21.What among the following is true about the UPDATE statement? (Choose the most appropriate answer)

  1. UPDATE может обновлять строки только из одной таблицы
  2. ОБНОВЛЕНИЕ может обновлять строки из нескольких таблиц
  3. Одна команда UPDATE не может влиять на строки в нескольких таблицах
  4. Ни один из вышеперечисленных

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?

  1. UPDATE employees
    SET job_id  = 'ACCOUNTANT'
    WHERE employee_id   = 7389;
  2. INSERT INTO EMPLOYEES (employee_id  , first_name , job_id ) VALUES (5100,'BRUCE', 'ACCOUNTANT');
  3. UPDATE employees
    SET job_id  = 'ACCOUNTANT'
    WHERE job_id  = 'CLERK';
  4. UPDATE employees
    SET job_id  = 'ACCOUNTANT';

Answer: A. Вариант B не работает, поскольку он изменяет код должности всех клерков на БУХГАЛТЕР. Вариант C неверен, потому что он обновляет код должности на БУХГАЛТЕР для всех сотрудников в таблице.

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?

  1. Код вакансии Брюса по-прежнему будет NULL
  2. Код должности Брюса будет изменен на "ПРОДАВЕЦ".
  3. Ошибка ORA
  4. Бездействие

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?

  1. Обновление будет работать успешно, пока в списке отображается 7389.
  2. Обновление будет работать успешно, в то время как при выборе не будет отображаться никаких записей.
  3. Ограничение EMPLOYEE_ID не позволяет его обновлять
  4. Он успешно обновится, но все значения EMPLOYEE_ID 7389 станут NULL.

Answer: B. Запрос в сеансе согласуется с текущими транзакциями. Если бы тот же запрос был выполнен в другом сеансе, он бы показал запись сотрудника с идентификатором 7389, потому что активная транзакция в первом сеансе еще не зафиксирована.

25. What among the following is a typical use of an UPDATE statement? (Select the most appropriate answer)

  1. Чтобы получить строку и обновить один или несколько столбцов этой строки
  2. Чтобы изменить все строки для некоторых столбцов
  3. Чтобы изменить все строки для всех столбцов таблицы
  4. Ни один из вышеперечисленных

Answer: A. Хотя оператор UPDATE может изменять все значения столбцов во всех строках, но обычно он используется для выбора строки и обновления одного или нескольких столбцов.

26. Which of the following practices appropriately describe for selecting which row set to update using the UPDATE statement?

  1. Если необходимо обновить некоторые строки, можно использовать ограничение PRIMARY KEY.
  2. Если все строки должны быть обновлены, можно рассмотреть предложение WHERE
  3. Чтобы обновить набор строк, используйте WHERE, чтобы обновить все строки таблицы, поместите ограничение PRIMARY KEY в таблицу
  4. Ни один из вышеперечисленных

Answer: C.

27. Which of the following columns in a table are not usually updated?

  1. Столбцы типа LONG в таблице
  2. Столбцы LOB в таблице
  3. Столбец первичного ключа, который также служит ссылкой на внешний ключ в другой таблице.
  4. Все вышеперечисленное

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;

Каков будет итог вышеизложенного заявления?

  1. Первая строка набора данных будет обновлена ​​до NULL.
  2. Третий столбец первой строки обновится до NULL
  3. Третий столбец всех строк будет обновлен до NULL
  4. И будет выдана ошибка ORA

Answer: C. Оператор UPDATE без предложения WHERE обновит все строки таблицы.

29. You issue an UPDATE statement as follows:

UPDATE employees 
SET employee_id   = NULL;
WHERE job_id  = 'CLERK';

Каков будет итог вышеизложенного заявления? (Здесь столбец EMPLOYEE_ID помечен как обязательный с помощью ограничения)

  1. Первый столбец набора данных будет обновлен до NULL
  2. Третий столбец первой строки обновится до NULL
  3. Третий столбец всех строк будет обновлен до NULL
  4. И будет выдана ошибка ORA

Answer: D. Ограничения на столбец должны соблюдаться при обновлении его значения. В данном операторе UPDATE будет выдана ошибка, поскольку столбец EMPLOYEE_ID является первичным ключом в таблице EMPLOYEES, что означает, что он не может быть NULL.

30. Which of the following commands can be used to remove existing records from a table?

  1. UPDATE
  2. INSERT
  3. MINUS
  4. DELETE

Answer: D. DELETE используется для удаления записей из таблицы, что может быть необязательно основано на условии. Будучи оператором DML, он является частью транзакции.

31. What among the following is true about the DELETE statement?

  1. Оператор DELETE должен сопровождаться предложением WHERE
  2. Не обязательно писать предложение WHERE с оператором DELETE.
  3. DELETE может удалять данные из нескольких таблиц за раз
  4. Ни один из вышеперечисленных

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)

  1. Появляется подсказка, спрашивающая пользователя, уверен ли он в удалении запрошенных строк.
  2. Строки, удовлетворяющие условию, указанному в инструкции DELETE, немедленно удаляются.
  3. Запрошенные строки удаляются немедленно без запроса.
  4. Ни один из вышеперечисленных

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

Вам необходимо удалить данные из столбца JOB_ID в строке с employee_id 51001. Какой из следующих запросов будет правильным?

  1. UPDATE employees
    SET job_id  = NULL
    WHERE employee_id   = 51001;
  2. DELETE job_id  FROM employees
    WHERE employee_id   = 51001;
  3. DELETE FROM employees;
  4. Ни один из вышеперечисленных

Answer: D. Вы не можете удалить определенное значение столбца для определенной строки с помощью оператора DELETE. Вся строка удаляется в соответствии с заданными условиями. Нежелательные значения в столбце могут быть обновлены до NULL. Вариант «А» близок, но неверен в контексте вопроса.

34. What is the difference between the UPSERT and MERGE statements?

  1. Нет никакой разницы
  2. UPSERT - это последний термин, принятый для оператора MERGE, который уже устарел.
  3. UPSERT может выполнять операцию удаления, которую MERGE не может
  4. 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?

  1. Оператор MERGE занимает больше времени, чем каждая операция (INSERT, UPDATE, DELETE), выполняемая отдельно
  2. MERGE устарел после Oracle 10g
  3. MERGE может выполнять все три операции с таблицей, в то время как INSERT, UPDATE и DELETE выполняют по одной операции за раз.
  4. Ни один из вышеперечисленных.

Answer: C. Оператор MERGE может объединить все три операции с таблицей в один оператор, в то время как INSERT, UPDATE и DELETE выполняют по одной операции за раз.

36. Which of the following objects can be the data source in a MERGE statement?

  1. Только стол
  2. Только подзапрос
  3. Таблица или подзапрос
  4. Оба A или B

Answer: C. MERGE хорошо работает с таблицей или подзапросом.

37. What among the following is a TRUNCATE statement equivalent to? (Choose the most suitable answer)

  1. К оператору DELETE
  2. К заявлению UPDATE
  3. Оператор DELETE без предложения WHERE
  4. Ни один из вышеперечисленных

Answer: C. TRUNCATE удаляет все строки одной командой.

38.Which of the following situations indicate that a DML operation has taken place?

  1. Когда в таблицу добавляются новые строки
  2. Когда два запроса объединены
  3. Когда таблица усекается
  4. Ни один из вышеперечисленных

Answer: A. Когда существующие строки в таблице вставляются, изменяются или удаляются из таблицы, это делается с помощью оператора DML.

39.Which of the following best defines a transaction?

  1. Транзакция состоит из операторов DDL в схеме базы данных.
  2. Транзакция состоит из COMMIT или ROLLBACK в сеансе базы данных.
  3. Транзакция состоит либо из набора операторов DML, либо из операторов DDL, DCL или TCL для формирования логической единицы работы в сеансе базы данных.
  4. Транзакция состоит из набора операторов 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?

  1. ACID свойство
  2. UNION
  3. СОЮЗ ВСЕ
  4. Transaction

Answer: D.

41.What happens when a DML statement in an active transaction encounters an error on execution?

  1. Откат всех транзакций
  2. DML в транзакции являются взаимоисключающими и, следовательно, могут продолжать свое выполнение.
  3. Остальные DML в транзакциях прерываются и ждут, пока ошибка не будет устранена.
  4. Ни один из вышеперечисленных

Answer: A. Если какой-либо из операторов DML в активной транзакции обнаруживает ошибку, вся транзакция завершается откатом.

42.What is true about the keyword VALUES in INSERT statements?

  1. VALUES может добавлять несколько строк за раз во время INSERT
  2. VALUES может добавлять только 100 строк за раз во время INSERT
  3. VALUES обязательно использовать, если мы используем ключевое слово INSERT
  4. 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?

  1. 0
  2. 2
  3. 3
  4. 1

Answer: D. Когда используется ключевое слово VALUES, оно вставляет только одну строку за раз.

44. In which order the values will get inserted with respect to the above INSERT statement?

  1. Location_id, manager_id, Department_name, Department_id
  2. Department_id, Department_name, manager_id, location_id
  3. Department_id, manager_id, Department_name, location_id
  4. 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.

  1. Он будет вставлять значения во все столбцы таблицы отделов, предполагая, что значения столбцов указаны в той же последовательности, что и столбец в таблице.
  2. Это вызовет ошибку ORA, потому что имена столбцов явно не упомянуты
  3. Это вызовет ошибку ORA, потому что предложение VALUES неправильно используется в INSERT
  4. Ни один из вышеперечисленных

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");
  1. Он вставит только employee_id и дату найма сотрудника, оставив все остальные столбцы как пустые.
  2. Будет вставлен только идентификатор employee_id
  3. Выдает ошибку ORA
  4. Ни один из вышеперечисленных

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");
  1. Он вставит только employee_id и имя Bryan, оставив все остальные столбцы пустыми.
  2. Будет вставлено только имя
  3. Выдает ошибку ORA
  4. Ни один из вышеперечисленных

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)
  1. INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O'callahan');
  2. INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O"callahan');
  3. INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O' 'Callahan');
  4. 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');
  1. Выдает ошибку числового значения
  2. Он вставит только employee_id и имя Bryan, оставив все остальные столбцы как NULL.
  3. Будет вставлен только идентификатор employee_id
  4. Ни один из вышеперечисленных

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);
  1. Выдает ошибку ORA
  2. Он будет выполнен успешно, но в столбцы могут быть вставлены неправильные значения.
  3. Он будет успешно выполнен
  4. Ни один из вышеперечисленных

Answer: C. NULL можно использовать в предложении VALUES для альтернативного заполнения значений столбца.

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);
  1. Выдает ошибку ORA
  2. Он будет выполнен успешно, но с неверными результатами
  3. Он будет выполнен успешно, но с правильными результатами
  4. Ни один из вышеперечисленных

Answer: A. Значения 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);
  1. Он будет выполнен успешно, но с неверными результатами
  2. Выдает ошибку ORA
  3. Он будет выполнен успешно, но с правильными результатами
  4. Ни один из вышеперечисленных

Answer: B. Тип данных значения не соответствует типу данных столбца в таблице.

53. Which of the following commands is used to save the changed data in a table permanently?

  1. ROLLBACK
  2. COMMIT
  3. INSERT
  4. UPDATE

Answer: B. Команда TCL COMMIT используется для завершения текущей активной транзакции в сеансе, делая все ожидающие изменения данных постоянными в таблицах.

54. Which of the following commands allows undoing the changed data?

  1. ROLLBACK
  2. COMMIT
  3. INSERT
  4. UPDATE

Answer: A. Команда TCL ROLLBACK используется для завершения текущей активной транзакции в сеансе путем отмены всех ожидающих изменений данных.

55. Which of the following commands allows enabling markers in an active transaction?

  1. ROLLBACK
  2. COMMIT
  3. SAVEPOINT
  4. Ни один из вышеперечисленных

Answer: C. SAVEPOINT отмечает точку в транзакции, которая делит транзакцию на более мелкие части.

56. Which of the following commands prevents other users from making changes to a table?

  1. ROLLBACK
  2. COMMIT
  3. ТАБЛИЦА БЛОКИРОВКИ
  4. 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)

  1. Он не может вставлять значения в виртуальный столбец
  2. Он может вставлять значения
  3. Выдает ошибку ORA
  4. Все вышеперечисленное

Answer: A. Виртуальный столбец - это столбец, который всегда автоматически создается на основе выражения деривации, определенного в спецификации столбца. Его значение не может быть явно вставлено пользователем.

58.Which of the following commands allows the user to insert multiple rows with a single statement?

  1. INSERT
  2. ВСТАВИТЬ ВСЕ
  3. СОЮЗ ВСЕ
  4. Ни один из вышеперечисленных

Answer: B. Операции массовой вставки могут выполняться с помощью INSERT ALL.

59. Which of the following is the syntax for inserting rows through a sub-query?

  1. INSERT INTO tablename [{column_name,..}]
    subquery;
  2. INSERT INTO tablename  VALUES [{column_name,..}]
    subquery;
  3. Оба а и Б
  4. Ни один из вышеперечисленных

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?

  1. UPDATE employees
    SET salary = salary + 1000
    WHERE to_char (hire_date, 'YYYY') > '2006';
  2. UPDATE employees
    SET salary = salary + 1000
    WHERE to_date (hire_date, 'YYYY') > '2006';
  3. UPDATE employees
    SET salary = salary + 1000
    WHERE hire_date > to_date (substr ('01-jan-200',8));
  4. 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?

  1. UPDATE employees
    SET department_id  = NULL
    Where job_id  = NULL;
  2. UPDATE employees
    SET department_id  = NULL
    Where job_id  = TO_NUMBER(NULL);
  3. UPDATE employees
    SET department_id  = NULL
    Where job_id  IS NULL;
  4. UPDATE employees
    SET department_id  = TO_NUMBER (' ', 9999)
    Where job_id  = TO_NUMBER(NULL);

Answer: C. Используйте оператор IS 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?

  1. INSERT INTO employees (employee_id , last_name, department_id ) 
    (100,'Bond',
    (select department_id  from departments where department_id  = 300));
  2. INSERT INTO employees (employee_id , last_name, department_id ) 
    VALUES (100,'Bond',
    (select department_id  from departments where department_id  = 300));
  3. INSERT INTO employees (employee_id , last_name, department_id ) 
    VALUES ('100','Bond',300);
  4. Ни один из вышеперечисленных

Answer: B, C. Подзапросы действительно работают в операторах INSERT при условии, что они возвращают скалярное значение типа данных, совпадающего или совместимого с столбцом, для которого они используются.

63. You fire the following query:

DELETE FROM EMPLOYEES;

Предполагая, что в таблице EMPLOYEES нет активных транзакций ни в одном сеансе, какое из следующих утверждений верно?

  1. Удаляет все строки и структуру таблицы
  2. Удаляет все строки, которые можно откатить
  3. Удаляет все строки навсегда
  4. Ни один из вышеперечисленных

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?

  1. Откат выдает ошибку
  2. Откатываются только операторы DELETE
  3. Ни один оператор SQL не откатывается
  4. Ни один из вышеперечисленных

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)

  1. Автоматический COMMIT
  2. Автоматический откат
  3. Может быть COMMIT или ROLLBACK для завершения транзакции
  4. Ни один из вышеперечисленных

Answer: B. Когда транзакция прерывается из-за сбоя системы, вся транзакция автоматически откатывается.

66. Which of the following commands / statements would end a transaction?

  1. COMMIT
  2. SELECT
  3. SAVEPOINT
  4. CREATE

Answer: A, D. Помимо команд TCL, то есть COMMIT или ROLLBACK, команды DDL и DCL обладают функцией автоматической фиксации. Активная транзакция будет зафиксирована, если оператор DDL выполняется в том же сеансе.

67.When does a transaction complete?

  1. Когда выполняется ROLLBACK
  2. Когда выполняется COMMIT
  3. Когда выполняется TRUNCATE
  4. Все вышеперечисленное

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);

Каков будет результат вышеуказанного запроса?

  1. Столбцы в таблице EMPLOYEES и в таблице отделов не совпадают.
  2. Предложение WHERE обязательно для использования в подзапросе.
  3. Ключевое слово VALUES нельзя использовать с предложением INSERT при использовании подзапросов.
  4. Ни один из вышеперечисленных

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);

Что из следующего верно относительно данного запроса?

  1. Он не будет выполнен, поскольку мы не можем использовать две таблицы в одном операторе обновления.
  2. Он не будет выполняться, поскольку UPDATE не может использовать подзапрос
  3. Он будет выполняться с ограничениями на указанный столбец
  4. Он не будет выполняться, поскольку в предложении WHERE используется подзапрос.

Answer: C.

70.What happens when a transaction is committed?

  1. Изменения, сделанные во время транзакции, сохраняются для конкретной пользовательской сессии.
  2. Изменения, сделанные во время транзакции, отменяются
  3. Если транзакция является DDL, фиксация не работает
  4. Ни один из вышеперечисленных

Answer: D. При фиксации транзакции ожидающие изменения данных постоянно сохраняются в базе данных.

71. Which of the following reasons will the best one on the usage of string?

  1. Использование подзапросов
  2. Синтаксические ошибки
  3. Разрешения на доступ
  4. Нарушения ограничений

Answer: C, B, D. Ссылки на несуществующие объекты / столбцы, проблемы с пространством могут быть другими причинами.

72. What happens when an INSERT statement tries to insert records in an old table?

  1. Все столбцы получат значения NULL
  2. Новая таблица с тем же именем будет создана автоматически, и значения будут вставлены
  3. INSERT не может работать и выдает ошибку ORA
  4. Ни один из вышеперечисленных

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?

  1. Джонатан подключен к базе данных, которая не поддерживает инструкции INSERT.
  2. Оператор INSERT нельзя применить к таблице EMPLOYEES.
  3. У Джонатана есть доступ к SELECT, но нет доступа к INSERT INTO в таблице EMPLOYEES
  4. Ни один из вышеперечисленных

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?

  1. Они останутся такими, какие есть
  2. Все они будут удалены
  3. Все они откатятся
  4. Ни один из вышеперечисленных

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?

  1. Он вставит строку с Department_id = 15 и всеми другими значениями как NULL
  2. Он будет выполнен успешно, но в таблицу будет вставлено 0 строк.
  3. Это вызовет ошибку ORA, поскольку нет. столбцов и значений не совпадают
  4. Ни один из вышеперечисленных

Answer: C. Таблица DEPARTMENTS содержит четыре столбца, но оператор INSERT предоставляет значение только для двух столбцов без упоминания столбцов. Следовательно, возникает ошибка ORA.

76. What is true about the above INSERT statement?

  1. Если столбцы не упоминаются в инструкции INSERT, значения вставляются в столбцы позиционно.
  2. Обязательно упоминание столбцов после оператора INSERT.
  3. Оба а и Б
  4. Ни один из вышеперечисленных

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?

  1. Заявление по-прежнему будет работать
  2. Выполнение оператора вызовет ошибку, так как в номере нет. столбцов и значений
  3. Изменений не будет, и оператор будет выполняться, как и раньше.
  4. Ни один из вышеперечисленных

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. Только запрос 1 лучше
  3. Только запрос 2 лучше
  4. Ни один из запросов не верен

Answer: C. Query-2 лучше, потому что он вставляет значение даты как дату, а не как строку. Хотя Oracle будет выполнять неявное преобразование строкового литерала, указанного как дата, но не рекомендуется.

79. Which of the following queries is equivalent of the query 2 given above?

  1. INSERT INTO employees (employee_id , last_name, hire_date)
    VALUES (101-1, upper('ADAMS'),to_date('21-DEC-12','DD-MON-YY'));
  2. INSERT INTO employees (employee_id , last_name, hire_date)
    VALUES (99+1, upper('ADAMS'),to_date('22-DEC-12','DD-MON-YY') +1 );
  3. INSERT INTO employees (employee_id , last_name, hire_date)
    VALUES (100, upper('ADAMS'),to_date('21-DEC-12','DD-MON-YY') - 1);
  4. 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?

  1. Вы можете использовать команду COPY
  2. Вы можете использовать команду INSERT
  3. Вы можете использовать команду UPDATE
  4. Ни один из вышеперечисленных

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)
  1. INSERT INTO job_history values (select * from job_history);
  2. INSERT INTO JOB_HISTORY_ARCHIVE values (select * from job_history_archive);
  3. INSERT INTO JOB_HISTORY_ARCHIVE select * from job_history;
  4. Ни один из вышеперечисленных

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.

  1. Выкинул ошибку
  2. Он вставит записи для всех сотрудников, нанятых за месяц до sysdate.
  3. Он вставит записи для всех сотрудников, которые являются торговыми представителями в отделе 10.
  4. Ни один из вышеперечисленных

Answer: B, C. INSERT ALL может выполнять условную вставку в целевые таблицы.

83. Which employees' data will be inserted in the department 20?

  1. Торговые представители
  2. Accountants
  3. Оба A или B
  4. Ни один из вышеперечисленных

Answer: B. Согласно инструкции INSERT ALL, сведения о сотрудниках, чей job_id не является «Торговым представителем».

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;
  1. Синтаксическая ошибка, поскольку переменные подстановки не могут использоваться в операторах DML
  2. Пользователю будет предложено ввести идентификатор сотрудника и зарплату, но переменные подстановки не могут вставить данные в таблицу.
  3. Пользователю будет предложено ввести идентификатор сотрудника, а зарплата и запись будут успешно созданы в таблице EMPLOYEES.
  4. Ни один из вышеперечисленных

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';

Каков был бы результат вышеупомянутых заявлений?

  1. Команда CREATE SEQUENCE вызовет ошибку, поскольку минимальное и максимальное значение для последовательности не были указаны.
  2. Все операторы будут выполнены успешно, и столбец employee_id будет содержать значение 2 для сотрудника STEYN.
  3. Команда CREATE SEQUENCE не будет выполнена, поскольку начальное значение последовательности и значение приращения не указаны.
  4. Все операторы будут выполнены успешно, и столбец employee_id будет иметь значение 20 для сотрудника STEYN, поскольку значение CACHE по умолчанию равно 20.

Answer: B.

86. What is the restriction on the sub-query used in the UPDATE statement?

  1. Подзапрос должен быть многострочным подзапросом
  2. Подзапрос должен быть подзапросом из одной строки
  3. Нет ограничений
  4. Подзапрос может быть одной строкой или многострочным подзапросом.

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?

  1. Выдает ошибку ORA при выполнении
  2. Заработная плата всех сотрудников будет обновлена ​​с той же зарплатой, что и у сотрудника 7382
  3. Заработная плата всех сотрудников будет обновлена ​​до NULL
  4. Ни один из вышеперечисленных

Answer: B. Результаты запроса можно использовать для обновления значений столбцов в таблице.

88. Suppose if the employee 7382 doesn't exist in the EMPLOYEES table. What will be the outcome of the query?

  1. При выполнении возникает ошибка ORA, поскольку результаты запроса не могут быть обновлены в столбцах.
  2. Заработная плата всех сотрудников будет обновлена ​​до NULL
  3. Исключение ORA 'NO_DATA_FOUND' будет вызвано, потому что сотрудник 7382 не существует
  4. Ни один из вышеперечисленных

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?

  1. Он успешно выполняется
  2. Все строки таблицы имеют одинаковую зарплату
  3. При выполнении может возникать ошибка ORA TOO_MANY_ROWS.
  4. Ни один из вышеперечисленных

Answer: C. Подзапрос может возвращать более одной строки, вызывая ошибку.

90. What changes in the above query will make sure there are no errors caused?

  1. Используйте функцию одной строки, такую ​​как MAX, MIN или AVG, чтобы преобразовать многострочные результаты в скалярный результат.
  2. Добавление ограничения первичного ключа в столбец SALARY
  3. Никаких изменений не требуется
  4. Ни один из вышеперечисленных

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?

  1. Он обновит зарплаты всех сотрудников, равные зарплате сотрудника по имени Адам.
  2. Он обновит зарплаты всех сотрудников, равные средней зарплате всех с фамилией «Адам».
  3. Он обновит 0 строк
  4. Он обновит только одну строку

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';

Каков будет результат основного запроса, приведенного выше?

  1. Он будет выполнен успешно, дав неверные результаты
  2. Он будет успешно работать, давая правильные результаты
  3. Выдает ошибку ORA
  4. Ни один из вышеперечисленных

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)

  1. Он обновит все зарплаты для всех сотрудников как 50000.
  2. Он обновит все зарплаты для всех сотрудников, которые находятся в отделе 10.
  3. Он обновит зарплаты для всех сотрудников, у которых есть один из идентификаторов должности, аналогичный идентификаторам в отделе 10.
  4. Ни один из вышеперечисленных

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);
  1. Он будет успешно выполнен с неверными результатами
  2. Он будет успешно выполнен с правильными результатами
  3. Выдает ошибку ORA
  4. Ни один из вышеперечисленных

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?

  1. Выполняется успешно, но строки не удаляются
  2. Все сотрудники, у которых last_name начинается с "A", будут удалены.
  3. Ошибка ORA, поскольку оператор DELETE не может иметь предиката WHERE
  4. Все строки из таблицы сотрудников будут удалены.

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, каков будет результат вышеуказанного запроса?

  1. Это вызовет ошибку ORA из-за недопустимых предикатов WHERE
  2. Он будет выполнен успешно, и никакие строки не будут удалены.
  3. Это вызовет ошибку ORA, потому что несколько предикатов не могут работать в операторах DELETE.
  4. Ни один из вышеперечисленных

Answer: B. К операторам DML UPDATE и DELETE можно применить несколько предикатов.

97. Consider the following query:

DELETE FROM employees where department_id  = &deptID;
COMMIT;

Что произойдет при выполнении вышеуказанного оператора?

  1. Это вызовет ошибку, потому что операторы DML не могут использовать переменные подстановки
  2. Он предложит удалить идентификатор отдела у пользователя и удалить запись с данным идентификатором отдела.
  3. Он запросит идентификатор отдела, но транзакция не может быть зафиксирована
  4. Ни один из вышеперечисленных

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?

  1. Atomicity
  2. Consistency
  3. Isolation
  4. Durability

Answer: A. ACID относится к основным свойствам транзакции базы данных: атомарности, согласованности, изоляции и долговечности. Атомарность подразумевает, что вся последовательность действий должна быть либо завершена, либо прервана. Согласованность подразумевает, что транзакция переводит ресурсы из одного согласованного состояния в другое. Изоляция подразумевает, что эффект транзакции не виден другим транзакциям, пока транзакция не будет зафиксирована. Долговечность означает, что изменения, внесенные зафиксированной транзакцией, являются постоянными и должны выдерживать сбой системы.

99. What does the principle of Durability in the ACID property state?

  1. В нем говорится, что база данных может потерять завершенные транзакции
  2. В нем говорится, что транзакция не может быть завершена
  3. В нем говорится, что после завершения транзакции БД не может потерять ее.
  4. Ни один из вышеперечисленных

Answer: C.

100. An incomplete transaction should be invisible to all the other users. Which of the properties of the ACID state this?

  1. Isolation
  2. Consistency
  3. Atomicity
  4. Durability

Answer: A. «Я» означает Изоляцию.

101. What does the principle of consistency states?

  1. В нем указано, что результаты запроса должны соответствовать состоянию БД на момент запуска запроса.
  2. В нем говорится, что незавершенная транзакция должна быть невидимой для всех других пользователей.
  3. В нем указано, что после завершения транзакции БД не может потерять ее.
  4. Ни один из вышеперечисленных

Answer: A. "C" в свойстве ACID означает согласованность.

102. What among the following best describes a Transaction?

  1. INSERT для COMMIT / ROLLBACK
  2. ОБНОВЛЕНИЕ до COMMIT / ROLLBACK
  3. УДАЛИТЬ до COMMIT / ROLLBACK
  4. INSERT / UPDATE / DELETE для 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?

  1. Когда Джонатан предоставляет разрешение на доступ пользователям
  2. Когда Джонатан выполняет оператор ROLLBACK в сеансе
  3. Когда Джонатан выполняет оператор COMMIT в том же сеансе
  4. Когда Джонатан открывает новый сеанс и выдает сообщение COMMIT

Answer: C. Активная транзакция должна быть зафиксирована в том же сеансе.

104. What can be said about the nesting of transactions?

  1. Возможны максимум 2 уровня вложенности
  2. Возможно максимально 255 уровней вложенности
  3. Вложение транзакции невозможно
  4. Возможен только 1 уровень вложенности

Answer: C.

105. Which of the following reasons will terminate a transaction?

  1. Заявление DDL
  2. Выход из клиента
  3. Системные сбои
  4. Все вышеперечисленное

Answer: D. DDL является автоматической фиксацией и завершает текущую активную транзакцию.