Использование вопросов операторов набора

1.Which SET operator does the following figure indicate?

  1. UNION
  2. СОЮЗ ВСЕ
  3. INTERSECT
  4. MINUS

Answer: A. Операторы набора используются для объединения результатов двух (или более) операторов SELECT. Допустимыми операторами набора в Oracle 11g являются UNION, UNION ALL, INTERSECT и MINUS. При использовании с двумя операторами SELECT оператор набора UNION возвращает результаты обоих запросов. Однако, если есть какие-либо дубликаты, они удаляются, и дублированная запись отображается только один раз. Чтобы включить дубликаты в результаты, используйте UNION ALL set operator.INTERSECT выводит список только записей, возвращаемых обоими запросами; оператор набора MINUS удаляет результаты второго запроса из вывода, если они также встречаются в результатах первого запроса. Операции над множеством INTERSECT и MINUS дают неповторимые результаты.

2.Which SET operator does the following figure indicate?

  1. UNION
  2. СОЮЗ ВСЕ
  3. INTERSECT
  4. MINUS

Answer: B. UNION ALL Возвращает объединенные строки из двух запросов без сортировки и удаления дубликатов.

3.Which SET operator does the following figure indicate?

  1. UNION
  2. СОЮЗ ВСЕ
  3. INTERSECT
  4. MINUS

Answer: C. INTERSECT Возвращает только строки, которые встречаются в наборах результатов обоих запросов, сортируя их и удаляя дубликаты.

4.Which SET operator does the following figure indicate?

  1. UNION
  2. СОЮЗ ВСЕ
  3. INTERSECT
  4. MINUS

Answer: D. МИНУС Возвращает только те строки в первом наборе результатов, которые не отображаются во втором наборе результатов, сортируя их и удаляя дубликаты.

5.What is true about SET operators?

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

Answer: D. Операторы набора используются для объединения результатов двух (или более) операторов SELECT. Допустимые операторы множества в Oracle 11g - UNION, UNION ALL, INTERSECT и MINUS.

6.What are the queries containing SET operators called?

  1. Sub-queries
  2. Связанные подзапросы
  3. GROUP BY запросы
  4. Составные запросы

Answer: D.

7.What is true about the UNION operator?

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

Answer: B. UNION Возвращает объединенные строки из двух запросов, сортируя их и удаляя дубликаты.

8.What is true about the UNION ALL operator?

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

Answer: C. UNION ALL Возвращает объединенные строки из двух запросов без сортировки и удаления дубликатов.

9.What is true about the INTERSECT operator?

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

Answer: C. INTERSECT Возвращает только строки, которые встречаются в наборах результатов обоих запросов, сортируя их и удаляя дубликаты.

10.What is true about the MINUS operator?

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

Answer: A. МИНУС Возвращает только те строки в первом наборе результатов, которые не отображаются во втором наборе результатов, сортируя их и удаляя дубликаты.

11.What is the precedence of the set operators UNION, UNION ALL, INTERSECT and MINUS?

  1. UNION, UNION ALL, INTERSECT и MINUS
  2. МИНУС, СОЕДИНЕНИЕ, СОЕДИНЕНИЕ ВСЕ и ПЕРЕСЕЧЕНИЕ
  3. ПЕРЕСЕЧЕНИЕ, МИНУС, СОЕДИНЕНИЕ ВСЕ, СОЕДИНЕНИЕ
  4. Равный приоритет

Answer: D. Операторы SET имеют равный приоритет.

12.What is the order of evaluation of set operators?

  1. Слева направо
  2. Справа налево
  3. Случайная оценка
  4. Сверху вниз

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

13.In which of the following cases, parenthesis should be specified?

  1. Когда INTERSECT используется с другими операторами множества
  2. Когда UNION используется с UNION ALL
  3. Когда для запросов используется МИНУС
  4. Ни один из вышеперечисленных

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

14.What is true about the SELECT clause when SET operators are used?

  1. Нет ограничений на выбираемые столбцы
  2. Столбцы и выражения, используемые в предложении SELECT, должны совпадать по количеству в комбинированных запросах.
  3. Столбцы и выражения, используемые в предложении SELECT, должны быть N в первом запросе и N-1 в последующих комбинированных запросах.
  4. И B, и C

Answer: B. Все вместе должны иметь одинаковый номер. столбцов при использовании операторов SET. Соответствующие столбцы в запросах, составляющих составной запрос, должны относиться к одной группе типов данных.

15.What is true about the SET operators?

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

Answer: C. Все вместе должны иметь одинаковый номер. столбцов при использовании операторов SET. Соответствующие столбцы в запросах, составляющих составной запрос, должны относиться к одной группе типов данных.

16.Where can the ORDER BY clause be used in case when SET operators are used?

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

Answer: C. Если предложение ORDER BY используется между любыми запросами, объединенными с помощью операторов SET, это вызовет ошибку ORA.

17.What is true about the queries that have SET operators in their WHERE clause?

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

Answer: A. Все вместе должны иметь одинаковый номер. столбцов при использовании операторов SET. Соответствующие столбцы в запросах, составляющих составной запрос, должны относиться к одной группе типов данных.

18.What is true about the columns in the second query with respect to the columns in the first query?

  1. Столбец во втором запросе должен быть в той же группе типов данных, что и соответствующий столбец в первом запросе.
  2. Если столбец в 1-м запросе - это ЧИСЛО, соответствующий столбец во 2-м запросе должен быть VARCHAR2.
  3. Если столбец в 1-м запросе - это ЧИСЛО, соответствующий столбец во 2-м запросе также должен быть ЧИСЛО.
  4. Ни один из вышеперечисленных

Answer: A, C.

19.What among the following is true about SET operators?

  1. Операторы SET нельзя использовать в подзапросах
  2. Операторы SET могут использоваться только в предложении WHERE
  3. ORDER BY можно использовать для всех запросов, объединенных оператором SET.
  4. Операторы SET могут использоваться в подзапросах

Answer: D.

20.What is the best way to change the precedence of SET operators given the fact that they have equal precedence?

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

Answer: C. Круглые скобки могут использоваться для группировки конкретных запросов, чтобы явно изменить приоритет. Скобки предпочтительнее других операторов SET во время выполнения.

21.What can be said about duplicate values and SET operators?

  1. Ни один оператор SET не отображает повторяющиеся значения
  2. Все операторы SET могут отображать повторяющиеся значения
  3. Только оператор UNION ALL отображает повторяющиеся значения
  4. Ни один из вышеперечисленных

Answer: C. UNION, INTERSECT и MINUS автоматически удаляют повторяющиеся значения

Examine the structure of the EMPLOYEES and DEPARTMENTS tables and consider the following query and answer the questions 22 and 23.

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SELECT department_id 
FROM employees e
UNION 
SELECT department_id 
FROM departments

22.What will be displayed in the result of this query?

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

Answer: A. UNION Возвращает объединенные строки из двух запросов, сортируя их и удаляя дубликаты.

23.What is true about the query given above?

  1. Этот запрос возвращает ошибку ORA
  2. Он выполняется успешно, но не дает результатов
  3. Запросы из разных таблиц нельзя использовать с операторами SET.
  4. Запрос выполняется успешно и дает ожидаемые результаты.

Answer: D. Составной запрос - это один запрос, состоящий из нескольких запросов с использованием разных таблиц.

24.What is the default sorting order of the results when UNION ALL operator is used?

  1. Descending
  2. Ascending
  3. Либо A, либо B
  4. Все вышеперечисленное

Answer: B. Составной запрос по умолчанию возвращает строки, отсортированные по всем столбцам слева направо в возрастающем порядке. Единственным исключением является UNION ALL, где строки не сортируются. Единственное место, где разрешено предложение ORDER BY, - это конец составного запроса.

25.What will be the output of the compound query in which columns in the SELECT are of CHAR and equal length?

  1. На выходе будет тип данных VARCHAR2 равной длины.
  2. Выходные данные будут иметь тип данных CHAR одинаковой длины.
  3. На выходе будет тип данных CHAR разной длины.
  4. Выходные данные будут иметь тип данных NUMBER одинаковой длины.

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

26.What will be the output of the compound query in which columns in the SELECT are of CHAR and different lengths?

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

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

27.What will be the output of a compound query if either or both queries select values of VARCHAR2?

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

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

28.What is true if the compound queries select numeric data?

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

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

29.What will happen if the SELECT list of the compound queries returns both a VARCHAR2 and a NUMBER data type result?

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

Answer: C. Oracle не преобразует типы данных неявно.

30.What is true about the UNION operator?

  1. Он устраняет повторяющиеся значения, игнорируя значения NULL
  2. Он возвращает повторяющиеся значения, игнорируя значения NULL
  3. Он возвращает повторяющиеся значения, включая значения NULL.
  4. Он исключает повторяющиеся значения и не игнорирует значения NULL

Answer: D. При использовании оператора UNION значения NULL не игнорируются

31.What can be said about the names and columns of a SQL query which uses the UNION operator?

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

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

Consider the following exhibit of the JOB_HISTORY table and the query that follows. Answer the questions 32 and 33 below the query.

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)
SELECT employee_id , first_name, last_name, job_id
FROM employees E
UNION
SELECT employee_id , first_name, last_name, job_id
From job_history;

32.How many times the each employee will get displayed by the above query?

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

Answer: B. UNION Возвращает объединенные строки из двух запросов, сортируя их и удаляя дубликаты.

33.What will be the outcome of the above query?

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

Answer: B.

Examine the given table structures and consider the following query and answer the questions 34 to 37 that follow:

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc 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)
SELECT employee_id , job_id, department_id 
FROM employees
UNION
SELECT employee_id , job_id, department_id 
From job_history;

34.Assuming that an employee with ID 121 has held 2 job IDs in his tenure in the company. Considering the above query, how many times will his records be displayed in the results?

  1. Once
  2. Twice
  3. Thrice
  4. Ни один из вышеперечисленных

Answer: B. UNION Возвращает объединенные строки из двух запросов, сортируя их и удаляя дубликаты. Дублирование измеряется комбинацией столбцов, а не отдельным столбцом по отдельности.

35.Assuming that the employee with ID 121 held two positions in two different departments - 10 and 20 in the company.He worked as 'SA_REP' in both the departments 10 and 20. What will be the outcome of the above query ?

  1. 2 ряда
  2. 3 ряда
  3. Нет строк
  4. Ошибка ORA

Answer: B.

36.Which statements best describes the inference drawn from the questions 34 and 35?

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

Answer: C. Поскольку комбинация кодов должностей и отделов уникальна, дубликаты не получаются.

37.What will be the sorting in the result set obtained by the query?

  1. По убыванию по идентификатору сотрудника
  2. По убыванию ID вакансии
  3. По возрастанию по идентификатору сотрудника
  4. По возрастанию по идентификатору отдела

Answer: C. Сортировка по умолчанию будет восходящей на основе первого столбца, то есть: в данном случае идентификатора сотрудника. Однако это поведение можно изменить, поместив в конце одно предложение ORDER BY.

38.Which of the following operators will be used to obtain duplicate records from the component queries?

  1. UNION
  2. СОЮЗ ВСЕ
  3. MINUS
  4. Ни один из вышеперечисленных

Answer: B. UNION ALL не удаляет повторяющиеся значения.

39.What is the difference between the UNION and the UNION ALL operators?

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

Answer: B, C. При использовании с двумя операторами SELECT оператор набора UNION возвращает результаты обоих запросов. Однако, если есть какие-либо дубликаты, они удаляются, и дублированная запись отображается только один раз. Чтобы включить в результаты дубликаты, используйте оператор множества UNION ALL

40.What is true about the INTERSECT operator?

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

Answer: A. Это общая характеристика критериев свойств операторов SET.

41.What can be said about the result set if the order of the intersected tables is altered when using INTERSECT?

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

Answer: B.

42.What among the following is true about the INTERSECT operator?

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

Answer: B.

Answer the related questions 43 and 44 given below.

43.You need to display the names and job IDs of those employees who currently have a job title that is the same as their previous one. Which of the following queries will work? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc 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. SELECT employee_id , job_id, first_name, last_name
    FROM employees
    UNION
    SELECT employee_id , job_id, first_name, last_name
    FROM job_history;
  2. SELECT employee_id , job_id, first_name, last_name
    FROM employees
    INTERSECT
    SELECT employee_id , job_id, first_name, last_name
    FROM job_history;
  3. SELECT employee_id , job_id, first_name, last_name
    FROM employees
    UNION ALL
    SELECT employee_id , job_id, first_name, last_name
    FROM job_history;
  4. Ни один из вышеперечисленных

Answer: B.

44.Considering the above query i.e. Option B in question 43, what will be the result if the department ID is also included in the SELECT clause?

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

Answer: A. Результат можно интерпретировать как - сотрудников, которые работали на одинаковой должности в одном отделе.

45.What is true about the MINUS operator?

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

Answer: D. Оператор набора MINUS удаляет результаты второго запроса из вывода, если они также встречаются в результатах первого запроса.

46.What can be said regarding the number of columns and data types of the component queries when a MINUS operator is used?

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

Answer: A. Общая особенность операторов SET.

47.You need to display the employee IDs of the employees who have not changed their jobs even once during tenure in the company. Which of the following queries will be correct in this case? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc 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. SELECT employee_id 
    FROM employees
    UNION
    SELECT employee_id 
    FROM job_history;
  2. SELECT employee_id 
    FROM employees
    INTERSECT
    Select employee_id 
    FROM job_history;
  3. SELECT employee_id 
    FROM employees
    MINUS
    Select employee_id 
    FROM job_history;
  4. SELECT employee_id 
    FROM employees
    UNION ALL
    SELECT employee_id 
    FROM job_history;

Answer: C.

Examine the given table structures and consider the following query answer the questions 48 and 49 that follow:

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
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)
SELECT employee_id , first_name, job_id
FROM employees
UNION
SELECT employee_id , NULL "first_name", job_id
FROM job_history;

48.What is true about the above query?

  1. Выдает ошибку, поскольку TO_CHAR (NULL) не может использоваться
  2. Он выполняется успешно и дает значения для идентификатора, first_name и текущей роли сотрудников, включая повторяющиеся строки.
  3. Он выполняется успешно и дает значения для идентификаторов сотрудников, first_name и всех заданий, выполняемых сотрудниками, за исключением повторяющихся строк.
  4. Ни один из вышеперечисленных

Answer: C. Каждый запрос должен содержать одинаковое количество столбцов, которые сравниваются позиционно. NULL можно заменить вместо столбца, который отсутствует в другом запросе в том же составном запросе.

49.Considering the above query, if the UNION operator is replaced by the MINUS operator, what will the result mean?

  1. Результат показывает тех сотрудников, у которых есть запись в таблице JOB_HISTORY.
  2. Результат показывает тех сотрудников, у которых нет записи в JOB_HISTORY, но они присутствуют в таблице EMPLOYEES.
  3. Либо A, либо B
  4. Ни один из вышеперечисленных

Answer: B. МИНУС дает уникальные результаты, которые присутствуют в первом запросе, но не во втором запросе.

Consider the exhibit given below and answer the questions 50 and 51 that follow:

50.What will be the outcome of the following query?

SELECT AU_DETAILS 
FROM AUDIT
UNION
SELECT AU_DETAILS
FROM AUDIT_YEARLY;
  1. Он выполняется успешно, давая правильные результаты, включая повторяющиеся значения.
  2. Он выполняется успешно, давая правильные результаты, за исключением повторяющихся значений.
  3. Выдает ошибку ORA
  4. Ни один из вышеперечисленных

Answer: C. Столбцы CLOB или LONG не могут быть в предложении SELECT при использовании операторов набора UNION.

51.What will be the outcome of the query if UNION is replaced with UNION ALL?

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

Answer: B. Операторы .UNION, UNION ALL, INTERSECT и MINUS при использовании со столбцом LONG или CLOB вызывают ошибку.

52.Assume that there are 4 component queries. How many SET operators can be used to combine them in a single compound query?

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

Answer: D. Будет использоваться оператор SET: N-1, где N - количество запросов компонентов.

53.What are SET operators called owning to the fact that two or more SELECTs are involved based on columns instead of rows when SET operators are used?

  1. Горизонтальные стыки
  2. Декартовы соединения
  3. Вертикальные стыки
  4. Внешние стыки

Answer: C.

54.What is the difference between a UNION and INTERSECT operators? (Choose only the best difference)

  1. UNION объединяет результаты двух компонентных запросов в один набор результатов с повторяющимися значениями
  2. INTERSECT возвращает только те строки, которые возвращаются каждым из двух компонентных запросов.
  3. UNION дает различные значения из запросов компонентов, INTERSECT дает общие значения из запросов компонентов
  4. И B, и C

Answer: C.

Examine the structure of the EMPLOYEES table and consider the following query. Answer the questions 55 to 60 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
SELECT *
FROM EMPLOYEES 
where department_id = 10
Query 2
SELECT *
FROM EMPLOYEES  E
where E.job_id IN (select first_name  from EMPLOYEES  E1 where E1.job_id = 'CLERK' and E.job_id  = E1.job_id )

55.You need to extract a report where the results from both the queries are displayed. Which of the following operators should be used to get the required results?

  1. UNION
  2. СОЮЗ ВСЕ
  3. INTERSECT
  4. Ни один из вышеперечисленных

Answer: B. UNION ALL Возвращает объединенные строки из двух запросов без сортировки и удаления дубликатов.

56.You need to display all the duplicate values along with all the values existing in the result set from both the queries. Which of the following SET operators you can use in the above given queries?

  1. INTERSECT
  2. UNION
  3. MINUS
  4. Ни один из вышеперечисленных

Answer: D. UNION ALL выдаст неотсортированные результаты с дубликатами.

57.What is the difference between the result sets when using a UNION and a UNION ALL set operators?

  1. Набор результатов UNION ALL фильтруется, включая повторяющиеся значения
  2. Набор результатов UNION фильтруется и сортируется, включая повторяющиеся значения.
  3. Набор результатов UNION ALL не отсортирован и имеет повторяющиеся значения
  4. Набор результатов UNION фильтруется и сортируется без повторяющихся значений

Answer: C, D.

58.The UNION operator has more overhead on the database than the UNION ALL. What is wrong in this statement?

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

Answer: A, C. UNION должен выполнять больше задач, чем UNION ALL, потому что он сортирует и дедуплицирует наборы результатов. Следовательно, рекомендуется использовать UNION ALL, если не требуются отдельные строки.

59.What will be the outcome if the two queries given above are combined using the INTERSECT operator?

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

Answer: A. INTERSECT возвращает те записи, которые присутствуют в запросе 1 И запросе 2.

60.What among the following is the difference between the INTERSECT and the UNION operators?

  1. INTERSECT следует булевой логике 'AND', UNION следует булевой логике 'OR'
  2. UNION следует логике OR, тогда как INTERSECT следует логике AND.
  3. Либо A, либо B
  4. Ни один из вышеперечисленных

Answer: A.

61.In which of the following SET operators, changing the order of the component queries will change the result set?

  1. UNION
  2. СОЮЗ ВСЕ
  3. MINUS
  4. INTERSECT

Answer: C. МИНУС Возвращает только те строки в первом наборе результатов, которые не отображаются во втором наборе результатов, сортируя их и удаляя дубликаты.

Consider the following query and answer the questions 62 to 66 that follow:

SELECT 4 from dual
INTERSECT
SELECT 1 from dual;

62.What will be the outcome of the given query?

  1. Нет строк
  2. 4
  3. 1
  4. NULL

Answer: A. Никакие строки не будут выбраны, поскольку оператор INTERSECT не получит общих результатов из обоих запросов - операторы INTERSECT дают общие результаты, представленные в запросе 1 И запросе 2.

63.What will be the outcome of the query if the INTERSECT operator is replaced with MINUS operator?

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

Answer: B. МИНУС дает результаты, которые присутствуют в первом запросе и отсутствуют во втором запросе.

64.What will be the outcome of the above query if the INTERSECT operator is replaced with the UNION operator?

  1. 1

    4

  2. 4

    1

  3. NULL
  4. 0

Answer: A. UNION создаст отдельные строки в результирующем наборе в порядке возрастания.

65.What will be the outcome of the above query if the INTERSECT operator is replaced with the UNION ALL operator?

  1. 4

    1

  2. 0
  3. NULL
  4. 1

    4

Answer: A. UNION ALL отображает результаты в том виде, в каком они расположены в запросе, без их сортировки.

66.What will be the outcome if the above query is modified as below?

SELECT 1 from dual
UNION ALL
SELECT 4 from dual;
  1. 1

    4

  2. 4

    1

  3. NULL
  4. Ни один из вышеперечисленных

Answer: A.

Examine the JOB_HISTORY_ARCHIVE table structure. It is a backup table for the JOB_HISTORY table with no additional column. Assuming that both the table have dissimilar data, consider the query given below and answer the questions 67 to 70 that follow:

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)
(SELECT * FROM job_history;
MINUS
SELECT * FROM job_history_archive)
UNION ALL
(SELECT * FROM job_history_archive
MINUS
SELECT * FROM job_history;);

67. What will be the outcome of the query given above? (Choose the best answer)

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

Answer: A.

68.What can concluded if the above given query yields rows only from JOB_HISTORY table?

  1. Он показывает, что JOB_HISTORY содержит две строки, отличные от таблицы JOB_HISTORY_ARCHIVE.
  2. Он показывает, что две строки в таблицах JOB_HISTORY и JOB_HISTORY_ARCHIVE совпадают.
  3. Он показывает, что JOB_HISTORY_ARCHIVE содержит две строки, отличные от таблицы JOB_HISTORY.
  4. Ни один из вышеперечисленных

Answer: A.

69.What can be said if the above query gives no results?

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

Answer: A.

70.With respect to the query given above, if duplicate records exist in the two tables, which of the following modifications should be made to the above given query?

  1. COUNT(*)
  2. COUNT (*) и GROUP BY employee_id
  3. COUNT (*) и ORDER BY employee_id
  4. Ни один из вышеперечисленных

Answer: B. COUNT (*) можно использовать, чтобы увидеть разницу между таблицами.

Consider the following query:

SELECT 1 NUM, 'employee' TEXT FROM dual
UNION
SELECT TO_CHAR(NULL) NUM, 'departments' TEXT FROM dual;

71.What will be the outcome of the query given above?

  1. NUM TEXT
    ---------- -----------
             1 employee
               departments
  2. NUM TEXT
    ---------- -----------
             1 employee
          NULL departments
  3. Ошибка ORA
  4. NUM TEXT
    ---------- -----------
               departments
             1 employee

Answer: C. Здесь число 1 сравнивается с символом NULL, который вызывает ошибку «ORA-01790: выражение должно иметь тот же тип данных, что и соответствующее выражение».

Consider the following query and answer the questions 72 and 73 that follow:

SELECT months_between (sysdate, to_date('21-MAY-2013','DD-MON-YYYY')) FROM dual
UNION
SELECT TO_date(NULL) NUM FROM dual;

72.What will be the outcome of the query given above? (Assume that the SYSDATE is 1st July, 2013)

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

Answer: C. NUMBER и DATE не принадлежат к одному и тому же типу данных. Здесь число, полученное с помощью MONTHS_BETWEEN, сравнивается с DATE и, следовательно, с ошибкой.

73.Assume that the SELECT statement in the 2nd query is modified as below:

SELECT to_number (NULL) NUM FROM dual;

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

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

Answer: A.

74.Examine the 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 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)
SELECT employee_id  "Employee ID"
FROM employees
UNION
SELECT employee_id  "EMP ID"
FROM job_history;

Какой из заголовков столбцов ниже будет отображаться в наборе результатов?

  1. EMP ID
  2. ID сотрудника
  3. EMPLOYEE_ID
  4. Ошибка ORA, потому что имена столбцов в запросах компонентов должны совпадать.

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

Examine the two table structures given and consider the following query and answer the questions 75 and 76 that follow:

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc 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)
SELECT employee_id 
FROM employees e
UNION
SELECT employee_id 
FROM job_history j
ORDER BY j.employee_id ;

75.What will be the outcome of the query given above?

  1. Результаты будут отсортированы по идентификатору сотрудника из таблицы JOB_HISTORY.
  2. Результаты будут отсортированы по идентификатору сотрудника из таблицы EMPLOYEES.
  3. Не будет упорядочивания результатов
  4. Ошибка ORA

Answer: D. ORDER BY следует выполнять на основе имен столбцов из первого запроса, а не из столбцов второго запроса.

76.Which of the following ORDER BY clauses can replace the erroneous ORDER BY in the query given above?

  1. ЗАКАЗАТЬ ПО e.employee_id
  2. ЗАКАЗ ПО j.2
  3. ЗАКАЗАТЬ ПО 1
  4. Ничего из вышеперечисленного, ORDER BY не допускается в запросе

Answer: C. Это более общая спецификация, и Oracle будет заказывать на основе первого столбца первого запроса.

77.Consider the following exhibit and answer the question below:

SELECT au_doc
From audit
UNION
SELECT au_doc
From audit_yearly;

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

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

Answer: B. Столбцы LONG нельзя использовать с операторами SET.

78.Consider the query given below:

SELECT col_1
From TABLE (package1.proc1)
UNION
SELECT col_1
From TABLE (package2.proc2);

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

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

Answer: C. Выражения TABLE нельзя использовать с операторами SET.

Examine the two table structures given and consider the following query. Answer the questions 79 and 80 that follow:

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc 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)
SELECT employee_id , job_id
FROM employees E
UNION
SELECT employee_id , job_id
FROM job_history J
FOR UPDATE OF job_id;

79.What happens when the query is executed?

  1. Ошибка ORA
  2. Employee_id и job_id
  3. Employee_id
  4. Ни один из вышеперечисленных

Answer: A. Предложение FOR UPDATE нельзя использовать с запросом, объединенным с помощью операторов SET.

80.What will be the outcome of the following query?

SELECT * from employees
UNION
SELECT job_id FROM job_history;;
  1. Он предоставит все столбцы из таблиц сотрудников и только столбец job_id из таблицы job_history
  2. Это вызовет ошибку, поскольку количество столбцов должно совпадать в запросах компонентов.
  3. Ни B, ни C
  4. Ни один из вышеперечисленных

Answer: B.

81.If UNION, UNION ALL, INTERSECT are used in one SQL statement which of the following is true regarding the SQL statement?

  1. UNION, UNION ALL будут выполнены сначала, а затем набор результатов перейдет для оператора INTERSECT.
  2. Выполнение INTERSECT будет предшествовать выполнению UNION и UNION ALL.
  3. Выполнение будет происходить справа налево с учетом всех операторов одновременно.
  4. Выполнение будет происходить слева направо с учетом всех операторов одновременно.

Answer: D.

82.Consider the query given below and answer the question that follow:

SELECT '3' FROM dual
INTERSECT
SELECT 3f FROM dual;

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

  1. Он успешно выполняется.
  2. Выдает ошибку
  3. Дает результат 3.
  4. Это дает результат 3f

Answer: B. Символьные литералы должны быть заключены в одинарные кавычки.

83.Which of the following is false for set operators used in SQL queries?

  1. Операторы набора действительны при использовании в столбцах с типом данных LONG.
  2. Операторы набора недействительны для столбцов типа BLOB, CLOB, BFILE, VARRAY или вложенной таблицы.
  3. Для запроса на выборку, содержащего выражение, должен быть указан псевдоним столбца, чтобы ссылаться на его предложение order_by_clause.
  4. Эти операторы нельзя использовать в операторах SELECT, содержащих выражения коллекции TABLE.

Answer: A. Операторы SET не поддерживаются для типов данных LONG, CLOB и BLOB.

84.Examine the given table structure and evaluate the following SQL statement:

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SELECT employee_id , last_name "Last Name"
FROM employees
WHERE department_id  = 100
UNION
SELECT employee_id  EMPLOYEE_NO, last_name
FROM employees
WHERE department_id  = 101;

Какие предложения ORDER BY действительны для указанного выше запроса? (Выберите все, что подходит.)

  1. ЗАКАЗАТЬ ПО 2,1
  2. ЗАКАЗ ОТ СОТРУДНИКА №
  3. ЗАКАЗАТЬ ПО 2, employee_id
  4. ЗАКАЗ ОТ "СОТРУДНИКА №"

Answer: A, C. Предложение ORDER BY должно ссылаться на столбец по его положению или имени, на которое ссылается первый запрос.

85.Which of the following clauses would you use to exclude the column from the 2nd query out of the two queries combined using SET operators?

  1. ГРУППА ПО
  2. СОРТИРОВАТЬ ПО
  3. MINUS
  4. UNION

Answer: C.

86.Examine the given table structure as given. What will be the outcome of the below query?

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SELECT distinct department_id 
FROM employees
WHERE salary > ANY (SELECT AVG (salary)
FROM employees
GROUP BY department_id )
UNION
SELECT *
FROM employees
WHERE salary > ANY (SELECT MAX (salary)
FROM employees
GROUP BY department_id );
  1. Он отобразит все идентификаторы отделов, которые имеют среднюю и максимальную зарплату.
  2. Это вызовет ошибку ORA, поскольку нет. столбцов, выбранных в обоих запросах, различаются
  3. Он отобразит все идентификаторы отделов со средними зарплатами.
  4. Он отобразит все идентификаторы отделов с максимальной заработной платой.

Answer: B. Нет. столбцов должны быть одинаковыми.

87.What among the following is true about the UNION operator?

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

Answer: C. UNION работает со всеми столбцами в списке SELECT и не игнорирует никакие столбцы.

88.You need to display the departments where the employees with the JOB IDs 'SA_REP' or 'ACCOUNTANT' work. Which of the following queries will fetch 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. SELECT department_id 
    FROM employees E
    Where job_id = 'SA_RE'
    UNION
    SELECT department_id 
    FROM employees E
    Where job_id = 'ACCOUNTANT';
  2. SELECT department_id 
    FROM employees E
    Where job_id = 'SA_REP'
    UNION ALL 
    Select department_id 
    FROM employees E
    Where job_id = 'ACCOUNTANT';
  3. SELECT department_id 
    FROM employees E
    Where job_id = 'SA_REP'
    INTERSECT
    Select department_id 
    FROM employees E
    Where job_id = 'ACCOUNTANT';
  4. SELECT department_id 
    FROM employees E
    Where job_id = 'SA_REP'
    MINUS
    Select department_id 
    FROM employees E
    Where job_id = 'ACCOUNTANT';

Answer: A.

89.Which of the following statement is true about the ordering of rows in a query which uses SET operator?

  1. ORDER BY нельзя использовать в отдельных запросах, составляющих составной запрос.
  2. Предложение ORDER BY может быть добавлено в конец составного запроса.
  3. Строки, возвращаемые UNION ALL, будут располагаться в том порядке, в котором они встречаются в двух исходных запросах.
  4. Строки, возвращаемые UNION, будут отсортированы по всем их столбцам справа налево.

Answer: A, B, C.

90.The UNION operator was used to fulfill which of the following function before the ANSI SQL syntax in place?

  1. ПРАВО НАРУЖНОЕ СОЕДИНЕНИЕ
  2. ЛЕВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ
  3. EQUI-JOIN
  4. ПОЛНОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ

Answer: D.

Answer the related questions 91 and 92 given below. Consider the table structures as given here:

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)

91.You need to find the job IDs which do not have any JOB history logged for them. Which of the following queries will work? (Consider the given table structures)

  1. SELECT job_id
    FROM employees 
    UNION ALL
    SELECT job_id
    FROM job_history;;
  2. SELECT job_id
    FROM employees 
    MINUS
    Select job_id
    FROM job_history;;
  3. SELECT job_id
    FROM employees 
    UNION
    SELECT job_id
    FROM job_history;;
  4. Ни один из вышеперечисленных

Answer: B.

92.Consider the following query:

SELECT distinct  job_id
FROM employees 
NATURAL JOIN job_history ;

Какой из следующих запросов идентичен приведенному выше?

  1. SELECT job_id
    FROM employees
    UNION 
    SELECT   job_id
    FROM job_history;;
  2. SELECT job_id
    FROM employees
    UNION ALL
    SELECT job_id
    FROM job_history;;
  3. SELECT job_id
    FROM employees
    MINUS
    Select job_id
    FROM job_history;;
  4. SELECT job_id
    FROM employees
    INTERSECT 
    SELECT job_id
    FROM job_history;;

Answer: A.

Examine the table structures given here. Consider the query given below and answer the related questions 93 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)
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)
SELECT job_id
FROM employees
UNION ALL
SELECT job_id
FROM job_history;;

93.If the EMPLOYEES table contains 5 records and the JOB_HISTORY contains 3 records, how many records will be obtained from the below query?

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

Answer: D. UNION ALL Возвращает объединенные строки из двух запросов без сортировки и удаления дубликатов.

94.If the UNION ALL operator is replaced with UNION operator, how many records will be obtained? (Assume there are 6 distinct values in both the tables)

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

Answer: D. UNION Возвращает объединенные строки из двух запросов, сортируя их и удаляя дубликаты.

95.If the UNION ALL operator is replaced with MINUS operator, how many records will be obtained? (Assume there are 3 distinct values in EMPLOYEES and 2 in JOB_HISTORY)

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

Answer: C. МИНУС Возвращает только те строки в первом наборе результатов, которые не отображаются во втором наборе результатов, сортируя их и удаляя дубликаты.

96.If the UNION ALL operator is replaced with INTERSECT operator, how many records will be obtained? (Assume there are 3 values common between the two tables)

  1. 8
  2. 6
  3. 3
  4. 2

Answer: C. INTERSECT Возвращает только строки, которые встречаются в наборах результатов обоих запросов, сортируя их и удаляя дубликаты.

97.Consider the following query:

1.select job_id
2. from employees
3.ORDER BY department_id 
4.UNION ALL
5.select job_id
6.FROM job_history;
7.ORDER BY department_id ;

Вышеупомянутый запрос вызывает ошибку. Какая строка в приведенном выше запросе вызывает ошибку?

  1. 3
  2. 7
  3. 2
  4. Ошибка не получена

Answer: A. ORDER BY должен появляться только в конце составного запроса, а не в компонентных запросах.

98.Which of the following SET operator features are supported in SQL/Foundation:2003 but not by Oracle?

  1. СОЮЗ ВСЕ
  2. МИНУС ВСЕ
  3. ПЕРЕСЕЧИТЬ ВСЕ
  4. ИСКЛЮЧАЯ ВСЕ

Answer: B, C, D.

99.You need to find out the common JOB IDs (excluding duplicates) in the departments 100 and 200. Which query will you fire to get the required results? (Consider the table structure as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
  1. SELECT job_id from employee
    WHERE department_id  = 100
    INTERSECT 
    SELECT job_id from employee
    WHERE department_id  = 200;
  2. SELECT job_id from employee
    WHERE department_id  = 100
    UNION ALL
    SELECT job_id from employee
    WHERE department_id  = 200;
  3. SELECT job_id from employee
    WHERE department_id  = 100
    MINUS
    Select job_id from employee
    WHERE department_id  = 200;
  4. SELECT job_id from employee
    WHERE department_id  = 100
    INTERSECT ALL
    Select job_id from employee
    WHERE department_id  = 200;

Answer: A.

100.If a compound query contains both a MINUS and an INTERSECT operator, which will be applied first? (Choose the best answer.)

  1. INTERSECT, потому что INTERSECT имеет более высокий приоритет, чем MINUS.
  2. МИНУС, потому что МИНУС имеет более высокий приоритет, чем ПЕРЕСЕЧЕНИЕ.
  3. Приоритет определяется порядком, в котором они указаны.
  4. Составной запрос не может включать одновременно MINUS и INTERSECT.

Answer: C. Все операторы множества имеют одинаковый приоритет, поэтому приоритет определяется последовательностью, в которой они встречаются.