Подзапросы для решения вопросов запросов

1. Which of the following are the types of sub-queries?

  1. Упорядоченные подзапросы
  2. Сгруппированные подзапросы
  3. Подзапросы одной строки
  4. Ни один из вышеперечисленных

Answer: C. Подзапрос - это полный запрос, вложенный в предложения SELECT, FROM, HAVING или WHERE другого запроса. Подзапрос должен быть заключен в круглые скобки и иметь как минимум предложения SELECT и FROM. Подзапросы с одной строкой и подзапросы с несколькими строками являются основными типами подзапросов.

2.Which of the following is true about sub-queries?

  1. Они выполняются после выполнения основного запроса
  2. Выполняются параллельно основному запросу
  3. Пользователь может выполнить основной запрос, а затем, при желании, выполнить подзапрос.
  4. Они выполняются до выполнения основного запроса.

Answer: D. Подзапрос всегда выполняется до выполнения основного запроса. Подзапросы выполняются первыми. Результат подзапроса используется в качестве входных данных для внешнего запроса.

3.Which of the following is true about the result of a sub-query?

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

Answer: C. Подзапросы выполняются первыми. Результат подзапроса используется в качестве входных данных для внешнего запроса.

4.Which of the following clause is mandatorily used in a sub-query?

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

Answer: A. Подзапрос аналогичен любому другому запросу, который должен начинаться с предложения SELECT. Они содержатся во внешнем запросе.

5. Which of the following is a method for writing a sub-query in a main query?

  1. Используя JOINS
  2. Используя предложение WHERE
  3. Используя предложение GROUP BY
  4. Путем написания оператора SELECT, встроенного в предложение другого оператора SELECT

Answer: D. Подзапрос - это полный запрос, вложенный в предложения SELECT, FROM, HAVING или WHERE другого запроса. Подзапрос должен быть заключен в круглые скобки и иметь как минимум предложения SELECT и FROM.

6.In the given scenarios, which one would appropriately justify the usage of sub-query?

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

Answer: C.

7.In which of the following clauses can a sub-query be used?

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

Answer: D. Подзапрос не отличается от обычного запроса. Он может использовать все основные предложения оператора SELECT.

8.Which of the following single-row operators can be used for writing a sub-query?

  1. >=
  2. <
  3. =
  4. Все вышеперечисленное

Answer: D. Однострочные операторы включают =,>, <,> =, <= и <>.

9.Which of the following multi-row operators can be used with a sub-query?

  1. IN
  2. ANY
  3. ALL
  4. Все вышеперечисленное

Answer: D. Многострочные подзапросы возвращают более одной строки результатов. Операторы, которые могут использоваться с многострочными подзапросами, включают IN, ALL, ANY и EXISTS.

10.What is true about the output obtained from a sub-query?

  1. Остается в буферном кеше
  2. Он остается внутри подзапроса и может быть использован позже при необходимости.
  3. Он используется для выполнения внешнего (основного) запроса
  4. И A, и C

Answer: C. Подзапросы выполняются первыми. Результат подзапроса используется в качестве входных данных для внешнего запроса.

11.You need to find the salaries for all the employees who have a higher salary than the Vice President of a company 'ABC'.Which of the following queries will give you the required result? (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 first_name, last_name, salary
    FROM employees 
    WHERE salary > (SELECT salary
    FROM employees 
    WHERE job_id = 'VICE-PRESIDENT');
  2. SELECT first_name, last_name, salary
    FROM employees 
    WHERE salary = (SELECT salary
    FROM employees 
    WHERE job_id = 'VICE-PRESIDENT');
  3. SELECT first_name, last_name, salary
    FROM employees 
    WHERE job_id = 'VICE-PRESIDENT');
  4. Ни один из вышеперечисленных

Answer: A. В варианте «A» внутренний подзапрос выдает зарплату вице-президента как результат внешнего запроса.

12.What among the following is true about sub-queries?

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

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

13. What will be the outcome of the following query? (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)
SELECT first_name, last_name, salary
FROM employees
WHERE salary ANY (SELECT salary FROM employees);
  1. Он успешно работает, давая желаемые результаты
  2. Выполняется успешно, но не дает желаемых результатов
  3. Выдает ошибку ORA
  4. Он выполняется успешно и дает два значения для каждой строки, полученной в наборе результатов.

Answer: C. Операторы с несколькими строками нельзя использовать в подзапросах с одной строкой и наоборот.

14.Which of the following is true about single-row sub-queries?

  1. Они дают один результат по основному запросу
  2. Они дают только одну строку в наборе результатов
  3. Они возвращают только одну строку из внутреннего оператора SELECT
  4. Они дают несколько строк из основного (внешнего) запроса

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

15.What is true about multi-row sub-queries?

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

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

16.What among the following is true about single-row sub-queries?

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

Answer: C.

17.Which of the following operators cannot be used in a sub-query?

  1. AND
  2. <
  3. >
  4. <>

Answer: A. Однострочные операторы включают =,>, <,> =, <= и <>. Многострочные операторы, которые можно использовать с многострочными подзапросами, включают IN, ALL, ANY и EXISTS.

Examine the exhibit and answer the questions 18 to 21 that follow.

18.You need to find out the names of all employees who belong to the same department as the employee 'Jessica Butcher' who is in department 100 and has an employee ID 40. Which of the following queries will be correct?

  1. SELECT first_name, last_name
    FROM employees
    WHERE last_name = 'Butcher'
    And first_name = 'Jessica';
  2. SELECT first_name, last_name
    FROM employees
    WHERE department =100;
  3. SELECT first_name, last_name
    FROM employees
    WHERE department  = (SELECT department
    FROM employees
    WHERE first_name = 'Jessica'
    AND last_name = 'Butcher');
  4. SELECT first_name, last_name
    FROM employees
    WHERE department  = (SELECT department
    FROM employees
    WHERE first_name = 'Jessica'
    AND last_name = 'Butcher'
    AND department = 100
    AND employee_id = 40);

Answer: D. «D» более подходит, чем «C», потому что он фильтрует идентификатор сотрудника, который является уникальным, и гарантирует, что подзапрос вернет только одну строку. «C» может потерпеть неудачу, если есть более одного сотрудника с одинаковыми именем и фамилией.

19.You need to find out the employees which belong to the department of 'Jessica Butcher' and have salary greater than the salary of 'Jessica Butcher' who has an employee ID of 40. Which of the following queries will work?

  1. SELECT first_name, last_name
    FROM employees
    WHERE last_name = 'Butcher'
    AND first_name = 'Jessica'
    AND salary > 10000;
  2. SELECT first_name, last_name
    FROM employees
    WHERE department = 100;
  3. SELECT first_name, last_name
    FROM employees
    WHERE department = (SELECT department
    			FROM employees
    			WHERE first_name = 'Jessica'
    			AND last_name = 'Butcher'
    			AND employee_id = 40)
    AND salary > (SELECT salary
    			 FROM employees
    			 WHERE first_name = 'Jessica'
    			 AND last_name = 'Butcher'
    			 AND employee_id = 40);
  4. SELECT first_name, last_name
    FROM employees
    WHERE department  = (SELECT department
    			FROM employees
    			WHERE first_name = 'Jessica'
    			AND last_name = 'Butcher'
    			AND department = 100);

Answer: C. В одном операторе SQL можно записать более одного подзапроса, чтобы добавить более одного условия.

20.Based on the answers for questions 18th and 19th, what type of sub-queries is used by them?

  1. Подзапрос одной строки
  2. Подзапрос с несколькими строками
  3. Оба а и Б
  4. Встроенный подзапрос

Answer: A. Вопросы 18 и 19, приведенные выше, демонстрируют подзапросы использования в операторе SELECT.

21.Consider two statements about outer and inner queries in context of SQL sub-queries?

я. Внутренние запросы могут получать данные только из одной таблицы

II. Внутренние запросы могут получать данные из более чем одной таблицы

Какие из приведенных выше утверждений верны?

  1. (i)
  2. (ii)
  3. Оба (i) и (ii)
  4. Ни (i), ни (ii)

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

Examine the table structure as follows and answer the questions 22 to 27 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)

22.What will be the outcome of the following query? (Choose the most appropriate answer)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SELECT last_name, job_id, salary
FROM employees
WHERE salary = (SELECT max(salary)
FROM employees);
  1. Он работает успешно и дает сотрудникам зарплату, равную максимальной зарплате.
  2. Выполняется успешно, но не дает требуемых результатов
  3. Выдает ошибку, поскольку в подзапросе используется групповая функция.
  4. Выдает ошибку, поскольку подзапрос с одной строкой должен содержать многострочный оператор.

Answer: A. В подзапросе можно использовать групповую функцию.

23.What will be the outcome of the query that follows?

SELECT first_name, last_name, min(salary)
FROM employees
GROUP BY department_id 
HAVING MIN(salary) > 
		(SELECT min(salary)
		FROM employees
		WHERE department_id = 100);
  1. Он выполняется успешно и дает имена и минимальную зарплату выше 100 всех сотрудников отдела.
  2. Он успешно работает и дает зарплату сотрудникам отдела 100.
  3. Он выполняется успешно и дает имена и минимальную заработную плату всех сотрудников.
  4. Выдает ошибку.

Answer: A. Предложение HAVING можно использовать в подзапросах, как показано

24.You need to find the job which has a maximum average salary.Which of the following queries will give you the required results?

  1. SELECT job_id, avg(salary)
    FROM employees
    GROUP BY job_id;
  2. SELECT job_id, avg(salary)
    FROM employees
    GROUP BY job_id
    HAVING job_id in (SELECT max(avg(salary) FROM employees);
  3. SELECT job_id, avg(salary)
    FROM employees
    GROUP BY job_id
    HAVING max(avg(salary) in (SELECT max(avg(salary) FROM employees);
  4. SELECT job_id, avg(salary)
    FROM employees
    GROUP BY job_id
    HAVING avg(salary) in (SELECT max(avg(salary) FROM employees GROUP BY job_id);

Answer: D. Подзапросы могут использовать групповые функции и предложение HAVING для ограничения групп.

25.The following query throws an error. Choose the correct reason for the error as given in the options.

SELECT first_name, last_name
FROM employees
WHERE commission_pct  = (SELECT min(commission_pct )
          FROM employees
          GROUP BY department_id);
  1. Предложение GROUP BY не требуется в подзапросе.
  2. Функцию нельзя использовать в инструкции SELECT подзапроса
  3. Подзапрос одной строки дает несколько записей
  4. Использование оператора "=" недопустимо; оператор IN будет работать правильно

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

26.Consider the query given below.How many records will be returned as a result of the above query? (Assuming the no employee with job id XX exists in the company)

SELECT first_name, last_name
FROM employees
WHERE salary = (SELECT salary
		FROM employees
		WHERE job_id = 'XX');
  1. 1
  2. NULL
  3. 0
  4. Запрос вызывает ошибку ORA, потому что подзапрос недействителен.

Answer: C. Поскольку в компании нет сотрудника с job_id "XX", подзапрос не возвращает результата, который при равенстве job_id в основном запросе дает 0.

27.What happens if the WHERE condition in the query given in question 26 is replaced with a new one (WHERE job_id IS NOT NULL)? (Assume the number of records in 'employees' table is 14).

  1. 1
  2. 14
  3. 0
  4. Ошибка ORA

Answer: D. При выполнении запроса возникает исключение «ORA-01427: однострочный подзапрос возвращает более одной строки».

28.Which of the following are valid multi row operators used for sub-queries?

  1. <=
  2. ЛЮБОЙ> =
  3. !=
  4. >=

Answer: B. Многострочные подзапросы возвращают более одной строки результатов. Операторы, которые могут использоваться с многострочными подзапросами, включают IN, ALL, ANY и EXISTS. Многострочные операторы IN, ANY, ALL должны использоваться с операторами одной строки, как показано в варианте Б.

Examine the table structure as given. Consider the query given below and answer the questions 29 to 33 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)
SELECT first_name, last_name, salary, commission_pct 
FROM employees 
WHERE salary < ANY  (SELECT salary
		FROM employees
		WHERE department_id  = 100)
AND department_id  <> 101;

29.What does the ANY operator evaluates to in the above query?

  1. TRUE
  2. FALSE
  3. NULL
  4. 0

Answer: A. Многострочные операторы возвращают логические результаты. Поскольку в отделе 100 есть результаты зарплаты, возвращается ИСТИНА. Если результатов 0, он оценивается как ЛОЖЬ.

30.What will be the outcome of the query if we assume that the department 100 has only one employee?

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

Answer: D. Если отдел 100 имеет один результат (подзапрос с одной строкой), оператор <ANY выдает ошибку, поскольку это оператор с несколькими строками.

31.What will be the outcome of the query given above if the < ANY operator is replaced with = ANY operator?

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

Answer: A. = ANY оператор эквивалентен оператору IN.

32.What can be said about the < ANY operator in the query given above?

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

Answer: C. Многострочный оператор <ANY оценивает утверждения подзапроса «Меньше максимума». '> ALL' Больше, чем наивысшее значение, возвращенное подзапросом. '<ВСЕ' Меньше наименьшего значения, возвращаемого подзапросом. '<ANY' Меньше максимального значения, возвращенного подзапросом. '<ANY' Больше, чем наименьшее значение, возвращаемое подзапросом. '= ANY' Равно любому значению, возвращаемому подзапросом (то же, что и IN). Строка "[НЕ] СУЩЕСТВУЕТ" должна соответствовать значению в подзапросе.

33.Assume that the < ANY operator is replaced with the > ANY. What is true about this operator?

  1. Дает максимальную зарплату
  2. Он находит только максимальную зарплату из подзапроса
  3. Дает больше минимальной зарплаты
  4. Дает минимальную зарплату

Answer: C. Многострочный оператор> ANY оценивает утверждения подзапроса «Больше минимума». '> ALL' Больше, чем наивысшее значение, возвращенное подзапросом. '<ВСЕ' Меньше наименьшего значения, возвращаемого подзапросом. '<ANY' Меньше максимального значения, возвращенного подзапросом. '> ANY' Больше, чем наименьшее значение, возвращаемое подзапросом. '= ANY' Равно любому значению, возвращаемому подзапросом (то же, что и IN). Строка "[НЕ] СУЩЕСТВУЕТ" должна соответствовать значению в подзапросе.

34. 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)
SELECT employee_id, first_name, last_name
FROM employees
WHERE salary IN (SELECT max(salary)
		FROM employees
		GROUP BY department_id );

Какое предложение WHERE из следующего эквивалентно предложенному в приведенном выше запросе? (Предположим, что зарплаты 2500, 3000, 3500, 4000)

  1. WHERE salary < ANY (SELECT max(salary)
    			FROM employees
    			GROUP BY department_id );
  2. WHERE salary < ALL (SELECT max(salary)
    			FROM employees
    			GROUP BY department_id );
  3. WHERE salary = (SELECT max(salary)
    			FROM employees
    			GROUP BY department_id );
  4. WHERE salary IN (2500,3000,3500,4000);

Answer: D. Когда используется оператор IN, Oracle обрабатывает отдельные результаты подзапроса, как показано в опции D.

Examine the structure of the EMPLOYEES table as given below and answer the questions 35 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)

35. You need to find out which of the employees have a salary less than that of the salary for the job ID 'FIN_ACT'. Which of the following queries will give you the required output?

  1. SELECT employee_id, first_name, last_name
    FROM employees
    WHERE salary < ALL 
    		(SELECT salary
    		 FROM employees
    		 WHERE job_id = 'FIN_ACT')
    		 AND job_id <> 'FIN_ACT';
  2. SELECT employee_id, first_name, last_name
    FROM employees
    WHERE salary > ALL 
    		(SELECT salary
    		FROM employees
    		WHERE job_id = 'FIN_ACT')
    		AND job_id <> 'FIN_ACT';
  3. SELECT employee_id, first_name, last_name
    FROM employees
    WHERE salary < ANY 
    		(SELECT salary
    		FROM employees
    		WHERE job_id = 'FIN_ACT')
    		AND job_id <> 'FIN_ACT';
  4. SELECT employee_id, first_name, last_name
    FROM employees
    WHERE salary = 	(SELECT salary
    		FROM employees
    		WHERE job_id = 'FIN_ACT')
    		AND job_id <> 'FIN_ACT';

Answer: A. <ВСЕ означает меньше минимума. '> ALL' Больше, чем наивысшее значение, возвращенное подзапросом. '<ВСЕ' Меньше наименьшего значения, возвращаемого подзапросом. '<ANY' Меньше максимального значения, возвращенного подзапросом. '> ANY' Больше, чем наименьшее значение, возвращаемое подзапросом. '= ANY' Равно любому значению, возвращаемому подзапросом (то же, что и IN). Строка "[НЕ] СУЩЕСТВУЕТ" должна соответствовать значению в подзапросе.

36.What will be the outcome of the above query (the option A in the question above), if the < ALL is replaced with the >ALL?

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

Answer: C. > ВСЕ означает меньше минимума. '> ALL' Больше, чем наивысшее значение, возвращенное подзапросом. '<ВСЕ' Меньше наименьшего значения, возвращаемого подзапросом. '<ANY' Меньше максимального значения, возвращенного подзапросом. '> ANY' Больше, чем наименьшее значение, возвращаемое подзапросом. '= ANY' Равно любому значению, возвращаемому подзапросом (то же, что и IN). Строка "[НЕ] СУЩЕСТВУЕТ" должна соответствовать значению в подзапросе.

37.You need to find the salaries for all employees who are not in the department 100. Which of the following queries will give you the required result?

  1. SELECT employee_id, first_name, last_name
    FROM employees
    WHERE salary !=ALL 
    		(SELECT salary
    		FROM employees
    		WHERE department_id  = 100)
    		AND department_id  <> 100;
  2. SELECT employee_id, first_name, last_name
    FROM employees
    WHERE salary NOT IN 
    		(SELECT salary
    		FROM employees
    		WHERE department_id  = 100)
    		AND department_id  <> 100;
  3. SELECT employee_id, first_name, last_name
    FROM employees
    WHERE salary NOT ALL 
    		(SELECT salary
    		FROM employees
    		WHERE department_id  = 100)
    		AND department_id  <> 100;
  4. SELECT employee_id, first_name, last_name
    FROM employees
    WHERE salary != (SELECT salary
    		FROM employees
    		WHERE department_id  = 100)
    		AND department_id  <> 100;

Answer: C. NOT можно использовать с многострочными операторами IN, ANY и ALL.

Изучите структуру таблицы, как указано. Обдумайте следующий вопрос и ответьте на следующие вопросы 38 и 39. Вам нужно найти сотрудников, у которых нет подчиненного, подчиненного им. (Предположим, что есть 0 ожидаемых результатов)

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 first_name, last_name 
FROM employees
WHERE employee_id NOT IN 
		(SELECT manager_id
		FROM employees);

38.What will be the result of the query given above?

  1. 10
  2. NULL
  3. Ошибка ORA
  4. 0

Answer: D. Одно из значений внутреннего подзапроса - NULL (все сотрудники не являются менеджерами!)

39.Which of the following WHERE clauses should be added / modified to the above query to give the expected results?

  1. WHERE employee_id != (SELECT manager_id FROM employees);
  2. WHERE employee_id IN (SELECT manager_id FROM employees);
  3. WHERE employee_id <>ALL (SELECT manager_id FROM employees);
  4. WHERE employee_id NOT IN (SELECT manager_id
    			FROM employees
    			WHERE manager_id is NOT NULL);

Answer: B, D. Если подзапрос, вероятно, будет иметь значения NULL, не используйте оператор NOT IN или, если он используется, измените подзапрос с дополнительным предложением WHERE (вариант D)

40.What is true about sub-queries in general?

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

Answer: C.

41. Which of the following is true about sub-queries?

  1. Подзапрос может возвращать 0 или более строк
  2. Подзапрос можно использовать только в предложении SELECT.
  3. Вложенность подзапросов ограничена 2 уровнями
  4. Групповые функции нельзя использовать в подзапросах

Answer: A. Подзапрос - это полный запрос, вложенный в предложения SELECT, FROM, HAVING или WHERE другого запроса. Подзапрос должен быть заключен в круглые скобки и содержать как минимум предложения SELECT и FROM. Однострочный подзапрос может возвращать не более одного значения. Подзапросы с несколькими столбцами возвращают внешнему запросу более одного столбца.

42. Examine the table structure as given.

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)

Рассмотрим следующий запрос.

SELECT first_name, last_name 
FROM employees
WHERE employee_id NOT IN 
		(SELECT manager_id, hire_date
		FROM employees 
		WHERE manager_id is not null);

Этот запрос возвращает ошибку. В чем причина ошибки?

  1. Используемый оператор NOT IN недействителен.
  2. Предложение WHERE в подзапросе написано неправильно
  3. Столбец в предложении SELECT подзапроса должен быть только один, если в основном запросе используется неравенство.
  4. Подзапрос использует ту же таблицу, что и основной запрос

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

43.A report has to be extracted which displays all the departments that have one or more employees assigned to them. Which of the following queries will give the required output? (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 department_name
    FROM employees
    WHERE department_id  IN (SELECT distinct (department_id )
    			FROM employees);
  2. SELECT department_name
    FROM employees
    WHERE department_id  ANY (SELECT distinct (department_id )
    			FROM employees);
  3. SELECT department_name
    FROM employees
    WHERE department_id  < ANY (SELECT distinct (department_id )
    			FROM employees);
  4. SELECT department_name
    FROM employees
    WHERE department_id  = ANY (SELECT distinct (department_id )
    			FROM employees);

Answer: A, D.

44.What is the maximum level of sub-queries allowed in Oracle in a single SQL statement?

  1. 20
  2. 50
  3. Unlimited
  4. 255

Answer: D. Oracle поддерживает вложение запросов до 255 уровней.

45. What should be the best practice to follow when we know what values we need to pass on to the main query in Oracle queries?

  1. Использование GROUP BY
  2. Использование подзапросов
  3. Использование HAVING
  4. Ни один из вышеперечисленных

Answer: D. Может стать возможным, что подзапросы дают результат NULL, что приводит к 0 строкам в основном результате; следовательно, рекомендуется использовать их только в том случае, если мы знаем, какие значения нам нужны.

Examine the table structure as given. Consider the following query and answer the questions 46 and 47 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)
SELECT employee_id, first_name, last_name, job_id
FROM employees
WHERE job_id = (SELECT job_id FROM employees);

46.You need to find all the employees whose job ID is the same as that of an employee with ID as 210. Which of the following WHERE clauses would you add / modify to achieve this result? (Consider the table structure as given

  1. WHERE job_id = (SELECT job_id FROM employees WHERE employee_id = 210);
  2. WHERE job_id IN (SELECT job_id FROM employees WHERE employee_id = 210);
  3. WHERE job_id > (SELECT job_id FROM employees WHERE employee_id = 210);
  4. WHERE job_id >= (SELECT job_id FROM employees WHERE employee_id = 210);

Answer: A.

47.Assume that you change the WHERE clause as given in the option A in question 46 as the following.

WHERE job_id = (SELECT job_id FROM employees WHERE employee_id < 210);

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

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

Answer: B. Подзапрос дает более одного результата при данном изменении, и, следовательно, многострочный оператор должен заменить «=» в основном запросе, приведенном выше.

48.Examine the table structures as shown in the exhibit below.

Вам нужно отобразить имена сотрудников, у которых самая высокая зарплата. Какой из следующих операторов SQL будет правильным?

  1. SELECT first_name, last_name, grade
    FROM employees, grade
    WHERE (SELECT max (salary) FROM employees) BETWEEN losal and hisal;
  2. SELECT first_name, last_name, grade
    FROM employees, grade
    WHERE (SELECT max (salary) FROM employees) BETWEEN losal and hisal
    AND salary BETWEEN losal and hisal;
  3. SELECT first_name, last_name, grade
    FROM employees, grade
    WHERE salary = (SELECT max (salary) FROM employees) 
    AND salary BETWEEN losal and hisal;
  4. SELECT first_name, last_name, grade
    FROM employees, grade
    WHERE salary IN (SELECT max (salary) FROM employees) 
    AND max(salary) BETWEEN losal and hisal;

Answer: B, C. Подзапросы можно писать по обе стороны от оператора

49.What is the sub-query in the FROM clause of an SQL statement? (Choose the most appropriate answer)

  1. Подзапрос одной строки
  2. Многострочный подзапрос
  3. Встроенный просмотр
  4. Связанный подзапрос

Answer: C. Если подзапрос появляется в предложении FROM операторов SELECT, он формирует встроенное представление. Oracle внутренне создает временное представление для выполнения запроса.

50.What is the maximum number of nesting level allowed in an Inline View type sub-query?

  1. 255
  2. 300
  3. 216
  4. Unlimited

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

51.What is true about co-related sub-queries?

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

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

52.Which of the following statements cannot be parent statements for a sub-query?

  1. SELECT
  2. ГРУППА ПО
  3. UPDATE
  4. DELETE

Answer: B. Остальные параметры могут быть в основном запросе (родительском запросе) подзапроса.

53.What is true about a co-related sub-query?

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

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

54.Examine the given table structure. You need to write a query which returns the names of the employees whose salaries exceed their respective department's average salary. Which of the following will work? (Choose the most appropriate answer)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
  1. SELECT employee_id, first_name, last_name
    FROM employees e
    WHERE salary > (SELECT avg (salary)
    		FROM employees
    		WHERE e.department_id  = department_id )
    		ORDER BY department_id ;
  2. SELECT employee_id, first_name, last_name
    FROM employees e
    WHERE salary > ANY (SELECT avg(salary)
    		FROM employees
    		WHERE e.department_id  = department_id )
    		ORDER BY department_id ;
  3. SELECT employee_id, first_name, last_name
    FROM employees e
    WHERE salary = (SELECT avg(salary)
    		FROM employees
    		WHERE e.department_id  = department_id )
    		ORDER BY department_id ;
  4. SELECT employee_id, first_name, last_name
    FROM employees e
    WHERE salary < ANY  (SELECT avg(salary)
    		FROM employees
    		WHERE e.department_id  = department_id )
    		ORDER BY department_id ;

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

55.Examine the given table structure. Which of the following queries will display duplicate records in a table EMPLOYEES?

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 *
    FROM employees E
    WHERE exists (SELECT 1 FROM employees E1
    		WHERE E.employee_id = E1.employee_id);
  2. SELECT *
    FROM employees E
    WHERE exists (SELECT 1 FROM employees E1
    		WHERE E.employee_id = E1.employee_id
    		AND E.ROWID < E1.ROWID);
  3. SELECT *
    FROM employees E
    WHERE exists (SELECT 1 FROM employees E1
    		WHERE E.ROWID < E1.ROWID);
  4. SELECT *
    FROM employees E
    WHERE = ANY (SELECT 1 FROM employees E1
    		WHERE E.employee_id = E1.employee_id
    		And E.ROWID < E1.ROWID);

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

Examine the structures for the tables DEPARTMENTS and EMPLOYEES and answer the questions 56 and 57 that follow.

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

56.Which of the following queries will display the system date and count of records in the DEPARTMENTS and EMPLOYEES table?

  1. SELECT sysdate,
    		(SELECT * FROM departments) dept_count,
    		(SELECT * FROM employees) emp_count
    FROM DUAL;
  2. SELECT sysdate,
    		(SELECT count(*) FROM departments) dept_count,
    		(SELECT count(*) FROM employees) emp_count
    FROM DUAL
    GROUP BY department_id ;
  3. SELECT sysdate,
    		(SELECT * FROM departments) dept_count,
    		(SELECT * FROM employees) emp_count
    FROM DUAL
    GROUP BY employee_id;
  4. SELECT sysdate,
    		(SELECT count(*) FROM departments) dept_count,
    		(SELECT count(*) FROM employees) emp_count
    FROM DUAL;

Answer: D. Однострочный подзапрос также может быть вложен в предложение SELECT внешнего запроса. В этом случае значение, которое возвращает подзапрос, доступно для каждой строки вывода, генерируемой внешним запросом. Обычно этот метод используется для выполнения вычислений со значением, полученным из подзапроса.

57.Which of the following queries will tell whether a given employee is a manager in a Company 'XYZ'?

  1. SELECT employee_id, manager_id
    FROM employees A
    WHERE employee_id ANY (SELECT manager_id from employees B)
    ORDER BY manager_id desc;
  2. SELECT employee_id, manager_id
    FROM employees A
    WHERE employee_id < ALL (SELECT manager_id from employees B)
  3. SELECT employee_id, manager_id
    FROM employees A
    WHERE employee_id IN (SELECT manager_id from employees B)
    ORDER BY manager_id desc;
  4. SELECT employee_id, manager_id
    FROM employees A
    WHERE employee_id in (SELECT manager_id from employees B)
    GROUP BY department_id ;

Answer: C.

Examine the exhibit and answer the question 58 that follows:

58.Which of the following queries will give you maximum salary of an employee in a particular city?

  1. SELECT max (salary), city
    FROM
    (SELECT salary, department_id , loc, city
    FROM employees natural join departments natural join locations);
  2. SELECT salary, city
    FROM
    (SELECT salary, department_id , loc, city
    FROM employees natural join departments natural join locations);
  3. SELECT max (salary), city
    FROM
    (SELECT salary, department_id , loc, city
    FROM employees natural join departments natural join locations)
    GROUP BY city;
  4. SELECT max (avg(salary)), city
    FROM
    (SELECT salary, department_id , loc, city
    FROM employees natural join departments natural join locations);

Answer: C. Когда подзапрос с несколькими столбцами используется в предложении FROM внешнего запроса, он создает временную таблицу, на которую могут ссылаться другие предложения внешнего запроса. Эта временная таблица более формально называется встроенным представлением. Результаты подзапроса обрабатываются так же, как и любая другая таблица в предложении FROM. Если временная таблица содержит сгруппированные данные, сгруппированные подмножества обрабатываются как отдельные строки данных в таблице.

Examine the table structures as given below.

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

Рассмотрите следующий вопрос и ответьте на вопросы с 59 по 62, которые следуют.

SELECT  department_name
FROM departments d INNER JOIN employees e
ON (d.employee_id = e.employee_id)
GROUP BY department_name;

59.Which of the following queries can replace the above query by using sub-queries giving the same result?

  1. SELECT department_name
    FROM departments
    WHERE department_id  = ANY (SELECT department_id  FROM employees);
  2. SELECT department_name
    FROM departments
    WHERE department_id  IN (SELECT distinct(department_id ) FROM employees);
  3. SELECT department_name
    FROM departments
    WHERE department_id  = (SELECT distinct(department_id ) FROM employees);
  4. SELECT department_name
    FROM departments
    WHERE department_id  ANY (SELECT distinct(department_id ) FROM employees);

Answer: A, B.

60.Assume that the sub-query as shown in the query given above is modified to the following.

(SELECT distinct (department_id ) FROM employees ORDER BY department_id );

Что будет в результате этого изменения? (Выберите наиболее подходящий ответ)

  1. Он упорядочит Department_id, извлеченный из подзапроса, и отобразит их в порядке возрастания.
  2. Это вызовет ошибку ORA, поскольку предложение ORDER BY должно сопровождаться предложением GROUP BY.
  3. Это вызовет ошибку ORA, потому что предложение ORDER BY не может использоваться внутри подзапроса.
  4. Он будет успешно выполнен.

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

61.Assume that the query given above is modified as the below one.

SELECT department_name
FROM departments
WHERE department_id  = ANY (SELECT department_id  FROM employees)
ORDER BY department_id  desc;

Что будет в результате этого изменения? (Выберите наиболее подходящий ответ)

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

Answer: D. Подзапрос, за исключением того, который указан в предложении FROM, не может иметь предложение ORDER BY. Если вам нужно отображать вывод в определенном порядке, включите предложение ORDER BY в качестве последнего предложения внешнего запроса.

62.Which of the following can be used to order results in a sub-query?

  1. СОРТИРОВАТЬ ПО
  2. HAVING
  3. ГРУППА ПО
  4. Все вышеперечисленное

Answer: C. По умолчанию предложение GROUP BY выполняет упорядочивание в подзапросе.

Examine the exhibit below and answer the questions 63 to 65 that follow:

Рассмотрим следующий запрос:

SELECT au_id, au_title
FROM audit
WHERE au_details in (SELECT au_details
		  FROM audit
		  WHERE au_title like 'S%')
		  ORDER BY au_title;

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

  1. Он дает все AU_ID и AU_TITLE, начинающиеся с буквы «S%».
  2. Он дает все AU_ID и AU_TITLE, начинающиеся с буквы «S%», упорядоченные по названиям в порядке возрастания.
  3. Выдает ошибку ORA
  4. Возвращает значение 0

Answer: C. Столбец с CLOB, BLOB, NCLOB или ARRAY не может использоваться в подзапросе.

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

SELECT *
FROM employees
WHERE salary BETWEEN (SELECT max(salary)
			FROM employees
			WHERE department_id  = 100) 
AND (SELECT min(salary) FROM employees where department_id  = 100);

Этот запрос возвращает ошибку. В чем причина ошибки?

  1. Предложение GROUP BY следует использовать, поскольку используется функция MAX
  2. Оба подзапроса не могут использовать один и тот же идентификатор отдела в одном внешнем запросе.
  3. Оператор BETWEEN нельзя использовать с подзапросом
  4. В предложении SELECT должны быть упомянуты столбцы, а не звездочка (*).

Answer: C. Оператор BETWEEN может использоваться внутри подзапроса, но не с подзапросом.

65.What is true about using NOT IN when writing queries with sub-queries in them?

  1. NOT IN игнорирует все значения NULL и дает только значения NOT NULL
  2. NOT IN помещает все значения NULL в последнее и дает NOT NULL для отображения первым
  3. NOT IN не следует использовать, если в результирующем наборе ожидается значение NULL.
  4. NOT IN - это просто отрицание оператора IN и может быть изменено без каких-либо оговорок.

Answer: C. SQL обрабатывает значения NULL по-другому, и поэтому рекомендуется избегать NOT IN, если набор результатов может содержать NULL.

Consider the following table structures and answer the questions 66 to 72 that follow:

66. You need to find out the names and IDs of the departments in which the least salary is greater than the highest salary in the department 10. Which of the following queries will give the required result.

  1. SELECT department_id , min(salary)
    FROM employees
    GROUP BY department_id 
    HAVING min(salary) >
    		(
    		select max(salary)
    		FROM employees
    		where department_id  = 10
    		)
  2. SELECT department_id , min(salary)
    FROM employees
    GROUP BY department_id 
    HAVING min(salary) > ANY
    		(
    		select max(salary)
    		FROM employees
    		)
  3. SELECT department_id , min(salary)
    FROM employees
    HAVING max(salary) < ANY
    		(
    		select min(salary)
    		FROM employees
    		where department_id  = 10
    		)
  4. SELECT department_id , min(salary)
    FROM employees
    GROUP BY department_id 
    HAVING min(salary) > ALL
    		(
    		select max(salary)
    		FROM employees
    		where department_id  = 10
    		)

Answer: A.

67.Write a query to find the employees whose salary is equal to the salary of at least one employee in department of id 10. (Choose the best answer)

  1. SELECT employee_id, Salary
    FROM employees
    WHERE salary in
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  2. SELECT employee_id, Salary
    FROM employees
    WHERE salary =ANY
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  3. SELECT employee_id, Salary
    FROM employees
    WHERE salary ALL
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  4. SELECT employee_id, Salary
    FROM employees
    WHERE salary  < ANY
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)

Answer: A, B.

68.You need to find out all the employees who have salary greater than at least one employee in the department 10. Which of the following queries will give you the required output?

  1. SELECT employee_id, Salary
    FROM employees
    WHERE salary >= ANY
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  2. SELECT employee_id, Salary
    FROM employees
    WHERE salary > ANY
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  3. SELECT employee_id, Salary
    FROM employees
    WHERE salary < ANY
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  4. SELECT employee_id, Salary
    FROM employees
    WHERE salary = ALL
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)

Answer: B.

69.You need to find out all the employees who have salary lesser than the salary of all the employees in the department 10. Which of the following queries will give you the required output?

  1. SELECT employee_id, Salary
    FROM employees
    WHERE salary > ALL
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  2. SELECT employee_id, Salary
    FROM employees
    WHERE salary =ALL
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  3. SELECT employee_id, Salary
    FROM employees
    WHERE salary < ALL
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)
  4. SELECT employee_id, Salary
    FROM employees
    WHERE salary < ANY
    		(
    		SELECT salary
    		FROM employees
    		where department_id  = 10
    		)

Answer: C. Подзапросы, состоящие из нескольких строк, возвращают более одной строки результатов. Операторы, которые могут использоваться с многострочными подзапросами, включают IN, ALL, ANY и EXISTS. Подзапросы с несколькими столбцами возвращают более одного столбца во внешний запрос. Столбцы данных передаются внешнему запросу в том же порядке, в котором они перечислены в предложении SELECT подзапроса.

70.You need to find out all the employees who have their manager and department matching with the employee having an Employee ID of 121 or 200. Which of the following queries will give you the required output?

  1. SELECT employee_id, manager_id,department_id 
    FROM employees
    WHERE (manager_id,department_id ) = ANY
    		(
    		select manager_id,
    		department_id 
    		FROM employees
    		where employee_id in (121,200)
    		)
  2. SELECT employee_id, manager_id,department_id 
    FROM employees
    WHERE (manager_id,department_id ) < ANY
    		(
    		select manager_id,
    		department_id 
    		FROM employees
    		where employee_id in (121,200)
    		)
  3. SELECT employee_id, manager_id,department_id 
    FROM employees
    WHERE (manager_id,department_id ) > ANY
    		(
    		select manager_id,
    		department_id 
    		FROM employees
    		where employee_id in (121,200)
    		)
  4. SELECT employee_id, manager_id,department_id 
    FROM employees
    WHERE (manager_id,department_id ) in
    		(
    		select manager_id,
    		department_id 
    		FROM employees
    		where employee_id in (121,200)
    		)

Answer: A, D. Подзапросы, состоящие из нескольких строк, возвращают более одной строки результатов. Операторы, которые можно использовать с многострочными подзапросами, включают IN, ALL, ANY и EXISTS. Подзапросы с несколькими столбцами возвращают внешнему запросу более одного столбца. Столбцы данных передаются внешнему запросу в том же порядке, в котором они перечислены в предложении SELECT подзапроса.

71.You need to find the department name of an employee with employee ID 200. Which of the following queries will be correct? (Choose the most appropriate answer)

  1. SELECT employee_id, first_name, last_name,department_id ,
    (SELECT department_name
    FROM departments d, employees E
    WHERE d.department_id  = e.department_id 
    And employee_id = 200
    )
    FROM employees e
  2. SELECT employee_id, first_name, last_name,department_id ,
    (SELECT department_ID
    FROM departments d
    WHERE d.department_id  = department_id 
    )
    FROM employees e
    WHERE employee_id = 200;
  3. SELECT employee_id, first_name, last_name,department_id ,
    (SELECT department_name
    FROM departments d
    WHERE d.department_id  = e.department_id 
    And employee_id = 200
    )
    FROM employees e
  4. SELECT employee_id, first_name, last_name,department_id ,
    (SELECT department_name
    FROM departments d,employee E 
    WHERE d.department_id  = e.department_id 
    )
    FROM employees e

Answer: C.

72.You need to find the highest earning employee with the job ID as 'SA_REP'. Which of the following queries will be correct? (Choose the most appropriate answer)

  1. SELECT job_id, employee_id, Salary
    FROM employees e
    WHERE job_id  =
    (
    SELECT  distinct salary
    FROM employees E1
    WHERE E.job_id  = E1.job_id 
    AND E.salary <=  E1.salary
    AND job_id  = 'SA_REP'
  2. SELECT department_id , employee_id, Salary
    FROM employees E
    WHERE 1 =
    (
    SELECT  count(distinct salary)
    FROM employees E1
    WHERE E.job_id  = E1.job_id 
    AND E.salary <=  E1.salary
    AND job_id  = 'SA_REP'
    )
  3. SELECT department_id , employee_id, Salary
    FROM employees E
    WHERE 0 =
    (
    SELECT  count(distinct salary)
    FROM employees E1
    WHERE E.job_id  = E1.job_id 
    AND E.salary =  E1.salary
    AND job_id  = 'SA_REP'
    )
  4. SELECT department_id , employee_id, Salary
    FROM employees E
    WHERE 1 =
    (
    SELECT salary
    FROM employees E1
    WHERE E.job_id  < E1.job_id 
    AND E.salary <=  E1.salary
    AND job_id  = 'SA_REP'
    )

Answer: B.

Consider the EMPLOYEES table structure as shown in the exhibit and answer the questions 73 to 77 that follow:

73.You need to find the job which has at least one employee in it. Which of the following queries will be correct? (Choose the most appropriate answer)

  1. SELECT employee_id, Job_id
    FROM employees E
    WHERE exists
    (
    SELECT 1
    FROM employees E1
    WHERE E.job_id  = E1.job_id )
  2. SELECT employee_id, Job_id 
    FROM employees E
    WHERE exists
    (
    SELECT *
    FROM employees E1
    WHERE E.job_id  = E1.job_id )
  3. SELECT employee_id, Job_id 
    FROM employees E
    WHERE not exists
    (
    SELECT *
    FROM employees E1
    WHERE E.job_id  = E1.job_id )
  4. SELECT employee_id, Job_id 
    FROM employees E
    WHERE exists
    (
    SELECT 1
    FROM employees E1
    WHERE E.job_id  < E1.job_id )

Answer: A. Оператор EXISTS используется для проверки и сопоставления записей между запросами. Возвращает БУЛЕВОЕ значение. Коррелированный подзапрос ссылается на столбец во внешнем запросе и выполняет подзапрос один раз для каждой строки внешнего запроса; а оператор EXISTS используется для проверки наличия связи или связи. Некоррелированный подзапрос сначала выполняет подзапрос и передает значение внешнему запросу.

74.You need to find the job which has no employees in it. Which of the following queries will be correct? (Choose the most appropriate answer)

  1. SELECT employee_id, Job_id 
    FROM employees E
    WHERE exists
    (
    SELECT *
    FROM employees E1
    WHERE E.job_id  = E1.job_id )
  2. SELECT employee_id, Job_id 
    FROM employees E
    WHERE not exists
    (
    SELECT 1
    FROM employees E1
    WHERE E.job_id  = E1.job_id )
  3. SELECT employee_id, Job_id 
    FROM employees E
    WHERE not exists
    (
    SELECT *
    FROM employees E1
    WHERE E.job_id  = E1.job_id )
  4. SELECT employee_id, Job_id 
    FROM employees E
    WHERE exists
    (
    SELECT 1
    FROM employees E1
    WHERE E.job_id  < E1.job_id )

Answer: B. NOT EXISTS - это оператор отрицания для EXISTS.

75.You need to find the 3rd maximum salary from the EMPLOYEES table. Which of the following queries will give you the required results? (Choose the most appropriate answer)

  1. SELECT * 
    FROM employees E
    WHERE salary = (SELECT count(distinct salary ) 
    		FROM employees 
    		WHERE e.salary = salary 
    		);
  2. SELECT * 
    FROM employees E
    WHERE 1 = (SELECT count(distinct salary ) 
    		FROM employees 
    		WHERE e.salary < salary 
    		);
  3. SELECT * 
    FROM employees E
    WHERE 2 = (SELECT count(distinct salary ) 
    		FROM employees 
    		WHERE e.salary >salary 
    		);
  4. SELECT * 
    FROM employees E
    WHERE 3 = (SELECT count(distinct salary ) 
    		FROM employees 
    		WHERE e.salary <= salary 
    		);

Answer: D.

76. You need to find the maximum salary by using the user input for getting the value of N. Which of the following queries will give you the required results? (Choose the most appropriate answer)

  1. SELECT salary FROM 
    (
    	SELECT rowid as user_sal 
    	FROM (SELECT distinct salary  from employees ORDER BY salary  desc)
    ) 
    WHERE user_sal=&N ;
  2. SELECT salary FROM 
    (	
    	SELECT rownum as user_sal
    	FROM (SELECT distinct salary  FROM employees   		GROUP BY salary )
    ) 
    WHERE user_sal <= &N ;
  3. SELECT salary FROM 
    (
    	SELECT rownum as user_sal, salary 	FROM (SELECT distinct salary  FROM employees 		 ORDER BY salary  desc)
    ) 
    WHERE user_sal=&N ;
  4. SELECT salary FROM 
    (
    	SELECT max(rownum) as user_sal, salary 	FROM (SELECT distinct salary  FROM employees 		ORDER BY salary  desc)
    ) 
    WHERE user_sal=&N ;

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

77.What will happen if a value is provided to the &N variable in the above query (option C in question 76) does not match with any row? (Choose the best answer)

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

Answer: D.

78.What is the maximum level up to which Sub-queries can be nested?

  1. 255
  2. 100
  3. 2
  4. 16

Answer: A.

79.What is true about the EXISTS operator in SQL queries with respect to sub-queries?

  1. Столбцы, выбранные в подзапросах, важны
  2. Внутренний запрос должен возвращать строки, важен любой результат, а не то, что ВЫБРАНО
  3. Оба а и Б
  4. Ни А, ни Б

Answer: B.

80.What is true about the ANY operator used for sub-queries?

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

Answer: C.

81.What is true about the ALL operator used for sub-queries? (Choose the most appropriate answer.)

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

Answer: C. '> ALL' Больше, чем наивысшее значение, возвращенное подзапросом. '<ВСЕ' Меньше наименьшего значения, возвращаемого подзапросом. '<ANY' Меньше максимального значения, возвращенного подзапросом. '> ANY' Больше, чем наименьшее значение, возвращаемое подзапросом. '= ANY' Равно любому значению, возвращаемому подзапросом (то же, что и IN). Строка "[НЕ] СУЩЕСТВУЕТ" должна соответствовать значению в подзапросе.

82.What is true about using sub-queries in INSERT statements in Oracle?

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

Answer: C.

Examine the table structures as given below and answer the questions 83 to 86 that follow.

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

83.You need to find the details of all employees who were hired for the job ID 'SA_REP' in the month of June, 2013. Which of the following queries will give the required results? (Consider the table structure as given)

  1. SELECT first_name 
    FROM employees 
    WHERE employee_id  =
    (	SELECT employee_id 
    	FROM employees 
    	WHERE to_char(hiredate, 'MM/YYYY')= '02/1981'
    	AND job_id  = 'SA_REP'
    );
  2. SELECT first_name 
    FROM employees 
    WHERE employee_id  = ANY
    (	SELECT employee_id 
    	FROM employees 
    	WHERE to_char(hiredate, 'MM/YYYY')= '02/1981'
    	AND job_id  = 'SA_REP'
    );
  3. SELECT first_name 
    FROM employees 
    WHERE employee_id  ANY
    (	SELECT employee_id 
    	FROM employees 
    	WHERE to_char(hiredate, 'MM/YYYY')= '02/1981'
    	AND job_id  = 'SA_REP'
    );
  4. SELECT first_name 
    FROM employees 
    WHERE employee_id  exists
    (	SELECT employee_id 
    	FROM employees 
    	WHERE to_char(hiredate, 'MM/YYYY')= '02/1981'
    	AND job_id  = 'SA_REP'
    );

Answer: B.

84.Which of the following statements are equivalent?

  1. SELECT employee_id , salary
    FROM employees 
    WHERE salary < ALL (SELECT salary FROM employees WHERE department_id=100);
  2. SELECT employee_id , salary
    FROM employees WHERE salary < (SELECT min(salary) FROM employees WHERE department_id=100);
  3. SELECT employee_id 
    FROM employees 
    WHERE salary not >= ANY (SELECT salary FROM employees WHERE department_id=100);
  4. Ни один из вышеперечисленных

Answer: A, B.

85.Consider the following two queries:

Query 1:
SELECT first_name 
FROM employees e join departments d
ON e.department_id  = d.department_id
WHERE department_name='ACCOUNTS';
Query 2:
SELECT first_name 
FROM employees  e 
WHERE department_id  = ANY (SELECT department_id 		FROM departments d 
		WHERE department_name='ACCOUNTS');

Что можно сказать об этих двух заявлениях?

  1. Оба запроса должны дать одинаковый результат.
  2. Оба запроса выдадут ошибку.
  3. Если есть два отдела с одинаковым именем, оба запроса не будут выполнены.
  4. Оба запроса будут выполнены успешно, даже если существует более одного отдела с именем "АККАУНТЫ".

Answer: A, D.

86.You need to display all the employees who have the highest salary in a department 100. You fire a query as below.

SELECT E.first_name, E.last_name , E.salary
FROM employees E
WHERE E.salary > ALL (SELECT E1.salary
      FROM employees E1
      WHERE E.department_id  =E1.department_id 
      AND E.department_id  = 100);

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

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

Answer: B, D. > ALL не даст требуемый результат, так как могут быть два сотрудника с одинаковой зарплатой, которые являются самыми высокооплачиваемыми в отделе 100

Consider table structures as shown in the exhibit and answer the questions 87 to 89 that follow:

87.You need to fetch the first names (in a reverse alphabetical order) of all the employees in the department ID = 100 and who have the maximum salary in the JOB ID = 'SA_REP'. Which of the following queries will give the required output? (Choose the most appropriate output)

  1. SELECT E.first_name, job_id , salary
    FROM employees E
    WHERE salary =
    		(SELECT max(salary)
    		FROM employees E1
    		WHERE E1.department_id  = 100
    		GROUP BY job_id )
    AND job_id  = 'SA_REP'
    ORDER BY first_name;
  2. SELECT E.first_name, job_id , salary
    FROM employees E
    WHERE salary in
    		(SELECT max(salary)
    		FROM employees E1
    		where E1.department_id  = 100)
    ORDER BY first_name;
  3. SELECT E.first_name, job_id , salary
    FROM employees E
    WHERE salary IN
    		(SELECT max(salary)
    		FROM employees E1
    		where job_id  = 'SA_REP'
    		GROUP BY job_id )
    AND WHERE E.department_id  = 100
    ORDER BY first_name desc;
  4. SELECT E.first_name, job_id , salary
    FROM employees E
    WHERE salary IN
    		(SELECT max(salary)
    		FROM employees E1
    		WHERE E1.department_id  = 100
    		GROUP BY job_id )
    ORDER BY first_name ;

Answer: C.

88.In the queries given above (option C is the correct answer), you need to display all the employees with the JOB ID 'SA_REP' who have the maximum salary in the department 100. Which of the following queries will give the required output?

  1. SELECT E.first_name, job_id , salary
    FROM employees E
    WHERE salary IN
    		(SELECT max(salary)
    		FROM employees E1
    		WHERE E1.department_id  = 100
    		GROUP BY job_id )
    AND job_id  = 'SA_REP'
    ORDER BY first_name;
  2. SELECT E.first_name, job_id , salary
    FROM employees E
    WHERE salary in
    		(SELECT max(salary)
    		FROM employees E1
    		WHERE E1.department_id  = 100)
    ORDER BY first_name;
  3. SELECT E.first_name, job_id , salary
    FROM employees E
    WHERE salary in
    		(SELECT max(salary)
    		FROM employees E1
    		WHERE job_id  = 'SA_REP'
    		GROUP BY job_id )
    And WHERE E.department_id  = 100
    ORDER BY first_name desc;
  4. SELECT E.first_name, job_id , salary
    FROM employees E
    WHERE salary in
    		(SELECT max(salary)
    		FROM employees E1
    		WHERE E1.department_id  = 100
    		GROUP BY job_id )
    ORDER BY first_name ;

Answer: A.

89.Select the query which will give you the maximum salary and maximum comm percentage. The query should also give the maximum comm percentage paid if the highest salaried employee gets the maximum comm percentage.

  1. SELECT employee_id, max(salary), max(commission_pct )
    FROM employees E
    GROUP BY salary, commission_pct ;
  2. SELECT employee_id, max(salary), max(commission_pct )
    FROM employees E
    GROUP BY salary;
  3. SELECT employee_id, max(salary)
    FROM employees E
    GROUP BY salary, commission_pct 
    HAVING max(commission_pct ) = 100;
  4. SELECT employee_id,
    (SELECT max(salary) FROM employees) * (SELECT max(commission_pct ) FROM employees)
    FROM DUAL;

Answer: D. Однострочный подзапрос также может быть вложен в предложение SELECT внешнего запроса. В этом случае значение, которое возвращает подзапрос, доступно для каждой строки вывода, генерируемой внешним запросом. Обычно этот метод используется для выполнения вычислений со значением, полученным из подзапроса.

90.What is true about the sub-queries used in the SELECT clause of an SQL statement?

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

Answer: B.

91.What will be the outcome of the following query? (Consider the table structure as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SELECT sysdate,
(SELECT max(salary) FROM employees GROUP BY department_id )
FROM DUAL;
  1. Он дает системную дату и максимальную зарплату для каждого отдела.
  2. Дает максимальную зарплату для всех отделов
  3. Выдает ошибку ORA
  4. Он успешно выполняется с 0 строками

Answer: C. Подзапрос с несколькими строками нельзя использовать в предложении SELECT инструкции SQL. В предложение SELECT внешнего запроса можно вложить только однострочный подзапрос.

Examine the given table structure. Consider the following query and answer the questions 92 to 95 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)
SELECT salary
FROM employees
WHERE salary > ALL (10, 20, 30);

92.Which of the following queries are equivalent to the above query?

  1. SELECT salary
    FROM employees
    WHERE salary >10 or salary > 20 and salary >30;
  2. SELECT salary
    FROM employees
    WHERE salary <10 and salary < 20 and salary <30;
  3. SELECT salary
    FROM employees
    WHERE salary >10 and salary > 20 and salary >30;
  4. SELECT salary
    FROM employees
    WHERE salary >10 and salary > 20 or salary < 30;

Answer: C. Вопрос показывает предложение ALL в упрощенном виде, когда за ним следует список.

93. If in the above query the list (10,20,30) is replaced by a sub-query, which of the following queries will give the required output for the department number 100?

  1. SELECT E.salary
    FROM employees E
    WHERE E.salary > (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  2. SELECT E.salary
    FROM employees E
    WHERE E.salary >ALL (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  3. SELECT E.salary
    FROM employees E
    WHERE E.salary = (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  4. SELECT E.salary
    FROM employees E
    WHERE E.salary >= (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);

Answer: B. Вопрос показывает предложение ALL в упрощенном виде, когда за ним следует подзапрос

94.With respect to the question 14 above, what among the following will be an equivalent query if ALL has to be replaced with ANY?

  1. SELECT E.salary
    FROM employees E
    WHERE NOT EXISTS (E.salary =ANY (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  2. SELECT E.salary
    FROM employees E
    WHERE E.salary >ANY (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  3. SELECT E.salary
    FROM employees E
    WHERE E.salary =ANY (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  4. SELECT E.salary
    FROM employees E
    WHERE NOT ( E.salary <= ANY (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100));

Answer: D. Оператор NOT, используемый при использовании '<= ANY', используется для отрицания результатов, возвращаемых подзапросом.

95.With respect to the question 94, if the operator ANY is not to be used, which of the following queries will be correct?

  1. SELECT E.salary
    FROM employees E
    WHERE NOT EXISTS (E.salary = ANY (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  2. SELECT E.salary
    FROM employees E
    WHERE NOT EXISTS (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100
    And E.salary <= E1.salary);
  3. Либо A, либо B
  4. Ни один из вышеперечисленных

Answer: B. Коррелированный подзапрос ссылается на столбец во внешнем запросе и выполняет подзапрос один раз для каждой строки внешнего запроса; а оператор EXISTS используется для проверки наличия связи или связи. Некоррелированный подзапрос сначала выполняет подзапрос и передает значение внешнему запросу.

Examine the given table structures. Consider the following query and answer the questions 96 to 98 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)
SELECT salary
FROM employees
WHERE salary > ANY (10, 20, 30);

96. Which of the following queries are equivalent to the above query?

  1. SELECT salary
    FROM employees
    WHERE salary >10 or salary > 20 and or >30;
  2. SELECT salary
    FROM employees
    WHERE salary <10 and salary < 20 and salary <30;
  3. SELECT salary
    FROM employees
    WHERE salary >10 and salary > 20 or salary >30;
  4. SELECT salary
    FROM employees
    WHERE salary >10 and salary > 20 or salary < 30;

Answer: A. Вопрос показывает предложение ANY в упрощенном виде, когда за ним следует список.

97. In the above query, if the list (10, 20, 30) is replaced by a sub-query, which of the following queries will give the required output for the department number 100?

  1. SELECT E.salary
    FROM employees E
    WHERE E.salary > (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  2. SELECT E.salary
    FROM employees E
    WHERE E.salary >ANY (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  3. SELECT E.salary
    FROM employees E
    WHERE E.salary = (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  4. SELECT E.salary
    FROM employees E
    WHERE E.salary >= (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);

Answer: B. Вопрос показывает предложение ANY в упрощенном виде, когда за ним следует подзапрос

98.With respect to the question 97 above, what among the following will be an equivalent query if ANY is removed?

  1. SELECT E.salary
    FROM employees E
    WHERE NOT EXISTS (E.salary =ANY (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);
  2. SELECT E.salary
    FROM employees E
    WHERE EXISTS (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100
    And E.salary >E1.salary);
  3. SELECT E.salary
    FROM employees E
    WHERE EXISTS (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100
    );
  4. SELECT E.salary
    FROM employees E
    WHERE IN (SELECT  E1.salary
    FROM employees E1
    WHERE E1.department_id  = 100);

Answer: B. Оператор EXISTS может заменить ЛЮБОЙ оператор. Коррелированный подзапрос ссылается на столбец во внешнем запросе и выполняет подзапрос один раз для каждой строки внешнего запроса; а оператор EXISTS используется для проверки наличия связи или связи.

99.Examine the given table structure. How many rows will get generated if the sub-query mentioned returns 0 rows?

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 E.salary
FROM employees E
WHERE E.salary > ANY ( select E1.salary FROM employees E1 where E1.department_id  = 100);
  1. 1 ряд
  2. Нет строк
  3. Либо A, либо B
  4. Ни один из вышеперечисленных

Answer: B. Если подзапрос возвращает ноль строк, условие '> ANY' оценивается как FALSE, следовательно, возвращается "No rows".

100. A subquery must be placed in the outer query's HAVING clause if:

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

Answer: B. Предложение HAVING используется, когда необходимо ограничить групповые результаты запроса на основании некоторого условия. Если результат подзапроса необходимо сравнить с групповой функцией, вы должны вложить внутренний запрос в предложение HAVING внешнего запроса.