Вопросы об условных выражениях

1. What is true about data types in Oracle DB?

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

Answer: C. Типы данных определяют характер данных, которые столбец может хранить в таблице. Столбец может хранить только один тип данных. Основными типами данных, доступными в Oracle, являются NUMBER, VARCHAR2 и DATE.

2. What is true about nested functions?

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

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

3. Which of the following functions simplify working with columns that potentially contain null values?

  1. Вложенные функции
  2. Общие функции
  3. Условные функции
  4. Ни один из вышеперечисленных

Answer: B. Общие функции, такие как NVL, NVL2, NULLIF и COALESCE, используются для смягчения эффекта NULL при отображении результатов запроса. Они обходят значения NULL, присваивая альтернативное значение.

4. Which of the following data types are appropriate for general functions?

  1. VARCHAR2
  2. NUMBER
  3. DATE
  4. Все типы данных

Answer: D. Общие функции обычно совместимы со всеми первичными типами данных, такими как NUMBER, VARCHAR2 и DATE.

5. What is true about the COALESCE function?

  1. Принимает минимум 2 и максимум 5 входных параметров.
  2. Он всегда возвращает первое значение NULL среди входных параметров.
  3. Может принимать неограниченное количество входных параметров
  4. Он возвращает первый ненулевой параметр, иначе он возвращает null.

Answer: C, D. Функция COALESCE принимает два обязательных параметра и любое количество дополнительных параметров. Синтаксис - COALESCE (expr1, expr2, Ö, exprn), где expr1 возвращается, если он не равен нулю, иначе expr2, если он не равен нулю, и так далее. COALESCE - это общая форма функции NVL, как показывают следующие два уравнения: COALESCE (expr1, expr2) = NVL (expr1, expr2), COALESCE (expr1, expr2, expr3) = NVL (expr1, NVL (expr2, expr3) )

6. How many input parameters are mandatory in NVL function?

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

Answer: C. Функция NVL принимает два обязательных параметра. Его синтаксис - NVL (оригинал, ifnull), где original представляет проверяемый термин, а ifnull - результат, возвращаемый, если исходный термин оценивается как null. Типы данных исходных параметров и параметров ifnull всегда должны быть совместимы. Они должны быть одного типа или должна иметься возможность неявного преобразования ifnull в тип исходного параметра. Функция NVL возвращает значение с тем же типом данных, что и исходный параметр.

7. What is wrong in the following statement?

NVL (ifnull, original)
  1. Нет ничего плохого
  2. Оригинал параметра не требуется
  3. Параметр ifnull не требуется
  4. Правильное выражение - NVL (оригинал, если пусто)

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

8. What will be the output of the following query?

SELECT NVL(1234) FROM dual;
  1. 1234
  2. 1000
  3. NULL
  4. ORA-00909: ошибка неверного числа аргументов

Answer: D. Функция NVL принимает два обязательных параметра. Его синтаксис - NVL (оригинал, ifnull), где original представляет проверяемый термин, а ifnull - результат, возвращаемый, если исходный термин оценивается как null.

9. What will be output of the following query?

SELECT NVL(1234,' ') FROM dual;
  1. Пустое пространство, т.е. ''
  2. 1234
  3. NULL значение
  4. ORA-01722: неверный номер

Answer: D. Типы данных исходных параметров и параметров ifnull всегда должны быть совместимы. Они должны быть одного типа или должна иметься возможность неявного преобразования ifnull в тип исходного параметра. Функция NVL возвращает значение с тем же типом данных, что и исходный параметр. 1234 следует заключить в одинарные кавычки. Неявного преобразования типа данных в этом случае не происходит.

10. What will be outcome of the following query?

SELECT NVL(SUBSTR('abc',-4),'SUBSTR didn't work') FROM dual;
  1. abc
  2. bc
  3. c
  4. SUBSTR не работал

Answer: D.

11. You need to extract a report which gives the first name, last name and the commission percentage earned by all the employees in department 100. The report should not have any columns which are empty. All the columns should have at least a '0' if there is no value for them. Which of the following queries will fulfill this requirement? (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, commission_pct*salary FROM employees WHERE department_id  = 100;
  2. SELECT first_name, last_name, NVL(commission_pct*salary,0) monthly_commission FROM employees WHERE department_id  = 100;
  3. SELECT first_name, last_name, NVL(commission_pct,0)*salary monthly_commission FROM employees WHERE department_id  = 100;
  4. SELECT first_name, last_name, commission_pct*salary FROM employees;

Answer: B, C.

12. What are the types of Data conversions in Oracle DB?

  1. Неявные преобразования
  2. Явные преобразования
  3. Внешние преобразования
  4. Физические преобразования

Answer: A, B. TO_CHAR, TO_NUMBER и TO_DATE - три наиболее широко используемых функции преобразования, которые подробно обсуждаются. Функция TO_CHAR преобразует числовую информацию и информацию о дате в символы, а TO_NUMBER и TO_DATE преобразуют символьные данные в числа и даты соответственно.

13. What happens during an implicit conversion in Oracle DB?

  1. Oracle DB неявно преобразует один тип данных в ожидаемый тип данных
  2. Пользователь должен преобразовать тип данных в ожидаемый тип данных.
  3. Oracle DB не конвертирует ни один тип данных
  4. Неявное преобразование может контролироваться пользователем

Answer: A. Если база данных Oracle неявно преобразует значение в совместимый тип данных, это называется неявным преобразованием.

14. What happens during an explicit conversion in Oracle DB?

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

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

15. Which of the following conversion methods is recommended for the reliability of SQL statements in Oracle DB?

  1. Неявные и явные преобразования
  2. Неявное преобразование
  3. Явное преобразование
  4. Ни один из вышеперечисленных

Answer: C. TO_CHAR, TO_NUMBER и TO_DATE - три наиболее широко используемых функции преобразования, которые подробно обсуждаются. Функция TO_CHAR преобразует числовую информацию и информацию о дате в символы, а TO_NUMBER и TO_DATE преобразуют символьные данные в числа и даты соответственно.

16. Which of the following is a valid implicit conversion performed by Oracle?

  1. НОМЕР ДЛЯ VARCHAR2
  2. НОМЕР ДО ДАТЫ
  3. ЧАР НА ДАТУ
  4. ДАТА VARCHAR2

Answer: A, D.

17. Examine the structure of the EMPLOYEES table 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, salary
FROM employees
WHERE hire_date > '01-JAN-13';
  1. Преобразования не происходит, и этот запрос приводит к ошибке ORA
  2. Явное преобразование
  3. Неявное преобразование
  4. Как неявное, так и явное преобразование

Answer: C. Строка (VARCHAR2 или CHAR) неявно преобразуется в DATE Oracle, выдавая требуемый результат в выбранном виде.

18. Which of the following is supported with respect to expression evaluation is supported by Oracle DB?

  1. ЧИСЛО В СИМВОЛ
  2. ДАТА VARCHAR2
  3. CHAR до DATE
  4. НОМЕР ДО ДАТЫ

Answer: A, B. Значения ДАТА и ЧИСЛО можно легко преобразовать в их символьные эквиваленты. Неявное преобразование символа в дату возможно, если строка символов соответствует следующим шаблонам даты: [D | DD] separator1 [MON | MONTH] separator2 [R | RR | YY | YYYY].

19. What is mandatory for and implicit conversion of CHAR to NUMBER in Oracle to work?

  1. Ничего особенного не является обязательным для этого типа конвертации.
  2. Строка символов обязательно должна представлять действительное число.
  3. Oracle не поддерживает такое преобразование.
  4. CHAR в NUMBER нужно только явно преобразовать

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

20. Which of the following expressions can be used explicitly for a conversion of a CHAR to a NUMBER?

  1. TO_CHAR
  2. Используйте TO_DATE, а затем преобразуйте дату в ЧИСЛО
  3. TO_NUMBER
  4. Такое преобразование невозможно

Answer: C. Функция TO_NUMBER возвращает элемент типа ЧИСЛО. Строки символов, преобразованные в числа, должны быть отформатированы соответствующим образом, чтобы любые нечисловые компоненты переводились или удалялись с помощью соответствующей маски формата.

21. Which of the following expressions can be used explicitly for a conversion of a NUMBER to a CHAR?

  1. TO_CHAR
  2. Используйте TO_DATE, а затем преобразуйте дату в ЧИСЛО
  3. TO_NUMBER
  4. Такое преобразование невозможно

Answer: A. Функция TO_CHAR возвращает элемент с типом данных VARCHAR2. При применении к элементам типа ЧИСЛО доступны несколько вариантов форматирования.

22. Which of the following expressions can be used explicitly for a conversion of a CHAR to a DATE?

  1. TO_CHAR
  2. Используйте TO_DATE, а затем преобразуйте дату в ЧИСЛО
  3. TO_NUMBER
  4. TO_DATE

Answer: D. Функция TO_DATE возвращает элемент типа DATE. Строки символов, преобразованные в даты, могут содержать все или только подмножество элементов даты и времени, составляющих DATE. При преобразовании строк только с подмножеством элементов даты и времени Oracle предоставляет значения по умолчанию для построения полной даты. Компоненты символьных строк связаны с различными элементами даты и времени с помощью модели формата или маски.

23. Which of the following expressions can be used explicitly for a conversion of a DATE to a CHAR?

  1. TO_CHAR
  2. TO_DATE
  3. TO_NUMBER
  4. Такое преобразование невозможно

Answer: A. Функция TO_CHAR возвращает элемент с типом данных VARCHAR2. При применении к элементам типа ЧИСЛО доступны несколько вариантов форматирования.

24. Which of the following are the functions for explicit conversion provided by Oracle to convert one data type to the other?

  1. TO_CHAR
  2. TO_DATE
  3. TO_NUMBER
  4. Все вышеперечисленное

Answer: D. TO_CHAR, TO_NUMBER и TO_DATE - три наиболее широко используемых функции преобразования, которые подробно обсуждаются. Функция TO_CHAR преобразует числовую информацию и информацию о дате в символы, а TO_NUMBER и TO_DATE преобразуют символьные данные в числа и даты соответственно.

25. Interpret the working of the below function.

TO_CHAR(number/date, [format], [nlsparameters])
  1. Преобразует VARCHAR2 в CHAR
  2. Он преобразует число / дату в строку VARCHAR2 с моделью формата [формат]
  3. Преобразует VARCHAR2 в ЧИСЛО или ДАТУ
  4. [NLSPARAMETERS] является обязательным в заявлении

Answer: B. Функция TO_CHAR возвращает элемент с типом данных VARCHAR2. При применении к элементам типа ЧИСЛО доступны несколько вариантов форматирования.

26. What does the [NLSPARAMETERS] clause in the following statement specify?

TO_CHAR(number/date, [format], [nlsparameters])
  1. Десятичный символ
  2. Разделитель групп
  3. Символ валюты
  4. Все вышеперечисленное

Answer: D.

27. What value will the TO_CHAR (number/date, [format], [nlsparameters]) use if the [nlsparameters] parameter is omitted?

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

Answer: C. По умолчанию функция TO_CHAR учитывает настройки NLS текущего активного сеанса.

28. What is true about the following statement?

TO_CHAR(number/date, [format], [nlsparameters])
  1. Параметр nlsparameters указывает язык, на котором возвращаются названия месяца и дня.
  2. Параметр nlsparameters опускается при выполнении вышеуказанного оператора.
  3. Параметр nlsparameters вернет NULL независимо от того, указан он или нет.
  4. Параметр nlsparameters будет возвращать язык БД по умолчанию при каждом выполнении.

Answer: A.

29. What is true regarding the following statement in Oracle DB?

TO_NUMBER(char, [format],[nlsparameters])
  1. Преобразует любую строку в число в формате, указанном в [format]
  2. Он преобразует только ЧИСЛО в желаемый формат, как указано в [формат]
  3. Он преобразует строку с цифрами в число в формате, указанном в [format]
  4. Результатом этой функции всегда является символ

Answer: C. Функция TO_NUMBER возвращает элемент типа ЧИСЛО. Строки символов, преобразованные в числа, должны быть отформатированы соответствующим образом, чтобы любые нечисловые компоненты переводились или удалялись с помощью соответствующей маски формата.

30. What is true regarding the following statement in Oracle DB?

TO_DATE(char, [format],[nlsparameters])
  1. Преобразует любую строку в DATE в формате, указанном в [format]
  2. Он преобразует только ДАТУ в другую ДАТУ в желаемом формате, как указано в [формат]
  3. Он преобразует строку с DATE в число в формате, указанном в [format]
  4. Он преобразует строку с DATE в DATE в формате, указанном в [format]

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

31. What will be the result if the [format] parameter in the following statement is omitted?

TO_DATE(char, [format],[nlsparameters])
  1. Он вернет значение DATE в формате DD-MON-YY.
  2. Он вернет значение DATE в формате DD-MON-RR.
  3. Он вернет символьное значение
  4. Он вернет ЧИСЛО значение

Answer: A.

32. Which of the following is true about the following statement in Oracle DB?

TO_CHAR(date, 'frmt')
  1. FMT можно записывать как в двойные, так и в одинарные кавычки.
  2. В этой функции регистр fmt не имеет значения
  3. Fmt может включать любой символ или ЧИСЛО
  4. FMT должен быть заключен в одинарные кавычки и должен иметь допустимый формат даты.

Answer: D.

33. What will the following statement on execution yield?

SELECT TO_CHAR ('01-JAN-13' 'DD-MON-YY') FROM dual;
  1. 01-JAN-13
  2. 01-01-2013
  3. Ошибка ORA
  4. 1-JAN-13

Answer: C. Параметры '01 -JAN-13 'и модель формата должны быть разделены знаком ",".

34. What is true about the [fmt] parameter in the following statement?

TO_DATE ([date as string],[format])
  1. FMT можно записывать как в двойные, так и в одинарные кавычки.
  2. В этой функции регистр fmt не имеет значения
  3. Параметр [fmt] имеет элемент 'fm', который удаляет пробелы и подавляет начальные нули.
  4. Fmt может включать любой символ или ЧИСЛО

Answer: C.

35. What is the abbreviation for the FM modifier in Oracle DB?

  1. Первый ход
  2. Режим фильтра
  3. Режим заполнения
  4. Первый режим

Answer: C. Модель формата «fm» означает режим заполнения.

36. What is the abbreviation for the FX modifier in Oracle DB?

  1. Первое выражение
  2. Заполнить выражение
  3. Первый Экстра
  4. Форматировать точно

Answer: D. Модель формата «fm» означает «точный формат».

37. How many maximum places for display will Oracle DB allocate to the Month element in the following statement?

SELECT TO_CHAR (sysdate, 'fmMonth') FROM dual;
  1. 5
  2. 6
  3. 7
  4. 9

Answer: D. Самое длинное слово для Месяца - «Сентябрь», и, следовательно, Oracle добавляет 9 мест для отображения параметра Месяц.

38. Which of the following is true about the FM modifier in Oracle DB?

  1. Этот модификатор подавляет пустое заполнение в последующих элементах символа, таких как МЕСЯЦ.
  2. Этот модификатор подавляет начальные нули для последующего числа элементов, таких как MI
  3. Этот модификатор не влияет на формат даты.
  4. Этот модификатор является обязательным для всех форматов даты, используемых с функцией TO_CHAR.

Answer: A, B.

39. What happens when the FM modifier is not used in the DATE format model in Oracle DB?

  1. Результат символьного элемента заполняется пробелами до переменной длины.
  2. Результат символьного элемента дополняется справа пробелами до фиксированной длины.
  3. Начальные нули не возвращаются в результате символьного элемента
  4. Длина возвращаемого значения фиксируется, если используется модификатор FM.

Answer: B.

40. How is a number result justified in the output buffer in a number format element of a TO_CHAR function when the FM modifier is used?

  1. Right
  2. Left
  3. Centre
  4. Ни один из вышеперечисленных

Answer: B. Модификатор FM подавляет добавление пробелов слева от числа.

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

SELECT TO_CHAR (TO_DATE('01-JAN-13'), 'fmDD Month YYYY') FROM dual;
  1. 1 января 2013 г.
  2. 1 января 2013 г.
  3. 1 января 2013 г.
  4. 1 13 января

Answer: B. TO_CHAR форматирует дату ввода в соответствии с заданной моделью формата.

42. How many spaces will be added to the 'DD' of the following query?

SELECT TO_CHAR (TO_DATE('01-JAN-13','DD-MON-YY'), 'fmDD Month YYYY') FROM dual;
  1. 0
  2. 1
  3. 2
  4. 3

Answer: A. Модификатор FM удаляет все заполненные пробелы из формата даты.

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

SELECT TO_CHAR (TO_DATE('01-JAN-13','DD-MON-YY'), 'fmDdspth "of" Month YYYY fmHH:MI:SS AM') FROM dual;
  1. Он вернет ошибку ORA из-за использования двойных кавычек в формате даты.
  2. 1 января 2013 г.
  3. 1 ЯНВАРЯ 2013 12:00:00
  4. 1 января 2013 г. 00:00:00

Answer: D. TO_CHAR форматирует дату ввода '01 -JAN-13 'в соответствии с заданным форматом.

44. Which of the following specifies the exact match for the character argument and the date format model of a TO_DATE function?

  1. TO_DATE
  2. TO_CHAR
  3. FM
  4. FX

Answer: D.

45. What is true about the FX modifier in the Oracle DB?

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

Answer: D.

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

SELECT TO_DATE ('January   21, 2013' , 'fxMonth DD, YYYY') FROM dual;
  1. Он будет успешно выполнен
  2. Даст результат 21 января 2013 г.
  3. Создает ошибку ORA
  4. Даст результат 21 ЯНВАРЯ 2013 г.

Answer: C. Символьный аргумент должен точно соответствовать модели формата, если используется FX. Здесь лишние пробелы после января не совпадают.

47. What is true about the FX modifier in Oracle DB?

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

Answer: C. Модификатор формата FX можно использовать только с функцией TO_DATE.

48. Assuming the SYSDATE is 01-JAN-13, what will be the outcome of the following query?

SELECT TO_CHAR (SYSDATE, 'DDTH') FROM dual;
  1. 1 января
  2. 1st
  3. 1 СТ
  4. 01ST

Answer: D.

49. Assuming the SYSDATE is 01-JAN-13, what will be the outcome of the following query?

SELECT TO_CHAR (SYSDATE, 'fmDDTH') FROM dual;
  1. 1 января
  2. 1st
  3. 1ST
  4. 01ST

Answer: C.

50. Assuming the SYSDATE is 01-JAN-13 and falls on Tuesday, what will be the outcome of the following query?

SELECT TO_CHAR (SYSDATE, 'fmDay')||'''s Meeting' FROM dual;
  1. Tuesday
  2. TUESDAY
  3. ВТОРНИК Встреча
  4. Встреча во вторник

Answer: D.

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

SELECT TO_DATE('01 / JAN / 13','DD-MON-YY') FROM dual;
  1. Ошибка ORA
  2. 01-JAN-2013
  3. 01-JANUARY-13
  4. 01-JAN-13

Answer: D.

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

SELECT TO_DATE('01 ## JAN / 13','DD-MON-YY') FROM dual;
  1. Ошибка ORA
  2. 01-JAN-2013
  3. 01-JANUARY-13
  4. 01-JAN-13

Answer: A. Используйте один разделитель между датами.

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

SELECT TO_DATE('01/JAN/13','fxDD-MON-YY') FROM dual;
  1. 01-JAN-2013
  2. Ошибка ORA
  3. 01-JAN-13
  4. 01-JANUARY-13

Answer: B. С модификатором точного формата входной литерал должен соответствовать строке формата.

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

SELECT TO_DATE('01-JAN-13','fxDD-MON-YY') FROM dual;
  1. 01-JAN-2013
  2. Ошибка ORA
  3. 01-JAN-13
  4. 01-JANUARY-13

Answer: C.

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

SELECT TO_DATE ('11-JAN-2013','fxDD-MON-YYYY') FROM dual;
  1. 11-JAN-13
  2. 11-01-13
  3. 11-JAN-2013
  4. Ошибка ORA

Answer: C.

56. An employee Allen was hired on 1-JAN -13. What will be the outcome of the following query? (Assume that the NLS parameter for the session is set to DD-MON-YY)

SELECT TO_DATE(hire_date, 'fxfmDD-MON-YY') FROM employees WHERE first_name='ALLEN';
  1. Ошибка ORA
  2. 01-JAN-2013
  3. 1-JAN-13
  4. 1-JAN-2013

Answer: C.

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

SELECT TO_CHAR(TO_DATE ('01-JAN-2013'), 'DD-Month-RR') FROM dual;
  1. 01-JAN-13
  2. 01-01-2013
  3. 01-January-13
  4. 01-января -13

Answer: D. Модификатор Месяц дополняется пробелами до 9 разрядов.

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

58. You need to list out the first and the last names for all the employees who were hired before the year 1990. Which of the following WHERE statements will give you the required results? (Assume that this list is to be generated on '01-JAN-2013')

  1. ГДЕ TO_DATE (дата_наема, 'ДД-МЕС-ГГ') <'01-ЯНВ-1990 '
  2. ГДЕ TO_DATE (дата_наема; 'ДД-МЕСЯЦ-ГГГГ') <'01-ЯНВ-1990 '
  3. ГДЕ ДО_ДАТА (дата_набора, 'ДД-МЕС-ГГ') <'01 -ЯНВ-90 '
  4. ГДЕ ДО_ДАТА (дата_набора, 'ДД-МН-РР') <'01-ЯНВ-1990 '

Answer: D. При использовании формата RR будет учитываться годовая часть даты между 1950 и 1999 годами.

59. Which of the following is an example of a nested function?

  1. SELECT lower(last_name) FROM employees;
  2. SELECT upper (last_name) FROM employees;
  3. SELECT concat (first_name, last_name) FROM employees;
  4. SELECT upper (concat(SUBSTR(first_name,1,6),'_UK')) FROM employees;

Answer: D. Наличие нескольких функций в функции называется вложением функций.

60. What is true about the COALESCE function in Oracle DB?

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

Answer: C. Функция COALESCE принимает два обязательных параметра и любое количество дополнительных параметров. Синтаксис - COALESCE (expr1, expr2, Ö, exprn), где expr1 возвращается, если он не равен нулю, иначе expr2, если он не равен нулю, и так далее.

61. Which of the following functions is used for conditional expressions?

  1. TO_CHAR
  2. COALESCE
  3. NVL
  4. CASE

Answer: D. Выражение CASE упрощает условную логику if-then-else. Есть два варианта выражения CASE. Простое выражение CASE перечисляет элемент условного поиска один раз, и равенство элементу поиска проверяется каждым выражением сравнения. В искомом выражении CASE указано отдельное условие для каждого выражения сравнения.

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

SELECT TO_CHAR(TO_DATE('01-JAN-13','DD-MON-YY'),'dy-mon-yyyy') FROM dual;
  1. 01-jan-2013
  2. 01-jan-13
  3. tue-jan-13
  4. tue-jan-2013

Answer: D. Модель формата «dy» состоит из первых трех букв дня, начиная с даты ввода. «DY» выдаст «ВТ», а не «ВТ», как в запросе, приведенном выше.

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

SELECT TO_CHAR(TO_DATE('01-JAN-13','DD-MON-YY'),'fmDAY-mon-yyyy') FROM dual;
  1. 1-jan-2013
  2. 01-jan-13
  3. ВТОРНИК -ЯНВ-13
  4. TUESDAY-jan-2013

Answer: D. Модель формата fmDAY (для всех заглавных букв) или fmday (для всех строчных букв) будет записывать день даты ввода без каких-либо завершающих или ведущих пробелов.

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

SELECT TO_CHAR(TO_DATE('19-JUN-13'),'qth') FROM dual;
  1. 1st
  2. 2nd
  3. 3rd
  4. 4th

Answer: B. Модель формата «q» дает квартал, в который попадает данная дата. В данном запросе АПР-ИЮН - это 2-й квартал.

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

65. Some employees joined company ABC in the second week of the current year i.e. 2013. You need to list out the first names, last names and the department IDs for all these employees. Which of the following queries will give you the required result?

  1. SELECT first_name, last_name, department_id  FROM employees WHERE TO_DATE(hire_date,'w') >2;
  2. SELECT first_name, last_name, department_id  FROM employees WHERE TO_DATE(hire_date,'w') between 1 and 2;
  3. SELECT first_name, last_name, department_id  FROM employees WHERE TO_CHAR(hire_date,'w') <3;
  4. SELECT first_name, last_name, department_id  FROM employees WHERE TO_CHAR(sysdate,'ww') =2;

Answer: D. Модель формата «ww» указывает неделю года.

66. The management of a company 'ABC' wants to find out how many employees were hired in the 3rd quarter of the year 2012. Which of the following queries will give the required result?

  1. SELECT count(employee_id  ) FROM employees WHERE TO_CHAR(hire_date, 'q') > 1;
  2. SELECT count(employee_id  ) FROM employees Where TO_CHAR(hire_date, 'q') = 3;
  3. SELECT employee_id   FROM employees Where TO_CHAR(hire_date, 'q') = 3;
  4. SELECT count(employee_id  ) FROM employees Where TO_CHAR(hire_date, 'q') between 0 and 3;

Answer: B. Модель формата «q» дает квартал года.

67. A certificate of achievement has to be printed and presented to all those employees who joined the organization before the year 2008 and are still a part of the organization. The printing of the first name, last name and the dates will happen by using placeholders fetched from a query. The Certificate should contain all the digits spelled out. Example: Tuesday, the 1st of January, Two Thousand and eight. The final text of the Certificate should be in the following form: This is to certify that first_name last_name who joined the organization on Tuesday, the 1st of January, Two Thousand and eight has successfully completed 5 glorious years in the company. Which of the following queries will be helpful in printing the dates as in the required format?

  1. SELECT TO_CHAR (hire_date, 'fmDay,"the "ddth "of " Month, Yysp.') FROM employees;
  2. SELECT TO_CHAR (hire_date, 'Day,"the "ddth "of " Mon, Yyyy.') FROM employees;
  3. SELECT TO_CHAR (hire_date, 'fmDAY,"the "ddth "of " Month, Ysp.') FROM employees;
  4. SELECT TO_CHAR (hire_date, 'fmDay,"the "ddth "of " MONTH, Rsp.') FROM employees;

Answer: A. Идентификатор sp обозначает год на простом английском языке.

68. A report has to be generated which creates an audit history table for all the employees from an available paper source. The paper source only has data for the year 2011 when the employees were hired. This data only has the year of the hire date. You need to put the date in the audit-history table as 1st of January of that particular year (without leading zeroes and spaces). Which of the following clauses will achieve this requirement?

  1. TO_DATE('2011','YYYY')
  2. TO_CHAR (TO_DATE ('2011', 'YYYY'), 'fmMM / DD / YYYY')
  3. TO_CHAR('2011','DD-MON-YYYY')
  4. TO_DATE ('01 -01-2011 ',' ДД-ММ-ГГГГ ')

Answer: B.

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

SELECT TO_NUMBER ('$3000') FROM dual;
  1. 3000
  2. $3000
  3. NULL
  4. Ошибка ORA

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

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

SELECT TO_NUMBER('$3,000.67','$999,999.99') FROM dual;
  1. $3000.67
  2. 3000
  3. 3000.67
  4. Ошибка ORA, поскольку входная строка содержит меньше символов, чем указанная модель формата.

Answer: C. Соответствующая модель формата помогает TO_NUMBER преобразовывать данную строку в числа.

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

SELECT TO_NUMBER('$3,000,000.67','$999,999.99') FROM dual;
  1. $3,000,000.67
  2. 3000,000.67
  3. 3000.67
  4. Ошибка ORA, поскольку в модели формата меньше символов, чем во входной строке. Должно быть так же.

Answer: D.

72. What will the following query yield?

SELECT TO_NUMBER('456.23','999.99') FROM dual;
  1. Ошибка ORA
  2. 456.23
  3. 456
  4. Ни один из вышеперечисленных

Answer: B.

73. What is true about the nested functions?

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

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

74. What will be the result of the following query?

SELECT NULLIF(1,2-1) FROM dual;
  1. 0
  2. 1
  3. NULL
  4. Ни один из вышеперечисленных

Answer: C. Функция NULLIF проверяет два условия на равенство. Если они равны, функция возвращает нуль, в противном случае она возвращает первый из двух проверенных терминов. Здесь 1 и выражение «2-1» считаются оракулом равными, и поэтому возвращается NULL.

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

SELECT NULLIF('01-JAN-2013','01-JAN-13') FROM dual;
  1. 1-JAN-13
  2. 01-JAN-2013
  3. NULL
  4. Ошибка ORA

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

76. What is the ratio of mandatory parameters to optional parameters in the COALESCE function in Oracle DB?

  1. 0:1
  2. 1:2
  3. 2: любое число
  4. Ни один из вышеперечисленных

Answer: C. Функция COALESCE принимает два обязательных параметра и любое количество дополнительных параметров. OALESCE - это общая форма функции NVL, как показывают следующие два уравнения: COALESCE (expr1, expr2) = NVL (expr1, expr2), COALESCE (expr1, expr2, expr3) = NVL (expr1, NVL (expr2, expr3) ).

77. Which of the following equations are true?

  1. COALESCE (expr1, expr2) = NVL (expr1, expr2)
  2. COALESCE (expr1, expr2) = NVL2 (expr1, expr2, expr3)
  3. COALESCE (expr1, expr2, expr3) = NVL (expr1, NVL (expr2, expr3))
  4. Все вышеперечисленное

Answer: A, C.

78. Which of the following is the correct syntax of NVL2?

  1. NVL(original,ifnotnull)
  2. NVL2(original,ifnull,ifnotnull)
  3. NVL(original,NULL)
  4. NVL (исходный, ifnull) и NVL2 (исходный, ifnotnull, ifnull)

Answer: D.

79. Which of the following functions is an ANSI standard keyword inherited in Oracle?

  1. CASE
  2. DECODE
  3. Оба а и Б
  4. Ни один из вышеперечисленных

Answer: A. CASE соответствует стандарту ANSI SQL, а не Oracle.

80. What is true about the DECODE statement in Oracle DB?

DECODE(expr1,comp1,iftrue1,comp2,[iftrue2])
  1. Comp2 не является обязательным
  2. Если expr1 равно comp1, то возвращается comp2
  3. Если expr1 равно comp1, тогда iftrue1 возвращается
  4. Ни один из вышеперечисленных

Answer: C. Функция DECODE реализует условную логику if-then-else, проверяя свои первые два члена на равенство и возвращает третий член, если они равны, и, при необходимости, возвращает другой член, если это не так. Функция DECODE принимает как минимум три обязательных параметра, но может принимать намного больше.

81. What is true about the parameters in the DECODE function?

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

Answer: D. Функция DECODE реализует условную логику if-then-else, проверяя свои первые два члена на равенство и возвращает третий член, если они равны, и, при необходимости, возвращает другой член, если это не так.

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

SELECT DECODE (null,null,'expr3') FROM dual;
  1. NULL
  2. 0
  3. Expr3
  4. Ошибка ORA

Answer: C. DECODE считает два значения NULL эквивалентными. Одна из аномалий NULL в Oracle.

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

SELECT DECODE ('elephant','rat','lion','tiger','cat','squirrel','elephant','koala','rat','And it continues') FROM dual;
  1. elephant
  2. rat
  3. koala
  4. И это продолжается

Answer: D. Функция DECODE принимает как минимум три обязательных параметра, но может принимать намного больше.

84. What is the number of minimum mandatory parameters for the CASE expression in Oracle DB?

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

Answer: D. Выражение CASE упрощает условную логику if-then-else. Есть два варианта выражения CASE. Простое выражение CASE перечисляет элемент условного поиска один раз, и равенство элементу поиска проверяется каждым выражением сравнения. В искомом выражении CASE указано отдельное условие для каждого выражения сравнения. Требуется минимум 3 обязательных параметра, но может быть и больше.

85. Which of the following keyword combinations is used to enclose a CASE statement in Oracle DB?

  1. CASEÖEND IF;
  2. IFÖEND IF;
  3. CASEÖ;
  4. CASEÖEND;

Answer: D.

86. Which of the following values is returned in case of a false value if the ELSE block in the CASE statement is undefined?

  1. 0
  2. NULL
  3. Либо 0, либо NULL
  4. Ни один из вышеперечисленных

Answer: B.

87. Which of the following options is true if more than one WHEN..THEN levels exist in a CASE statement?

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

Answer: B.

88. What data types can be the search, comparison and result parameters in the CASE statement?

  1. VARCHAR2
  2. DATE
  3. NUMBER
  4. Значения столбцов, литералы и выражения

Answer: D.

89. The CASE statement cannot be used in which of the following parts of an Oracle SQL query?

  1. SELECT
  2. Ни один из этих вариантов
  3. WHERE
  4. СОРТИРОВАТЬ ПО

Answer: B.

90. Examine the structure of the EMPLOYEES table 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)

Каков будет результат следующего запроса в Oracle DB?

SELECT first_name, salary,
CASE department_id WHEN 100
THEN 'Accounts'
WHEN 101
THEN 'Human Resources'
WHEN 102
THEN 'Sales'
ELSE 'Unknown'
 END
 FROM employees;
  1. Это вызовет ошибку ORA, поскольку в операторе CASE нельзя записать более одного оператора WHENÖTHEN.
  2. Он отобразит идентификаторы отделов как 100,101,102
  3. Он будет отображать только «Учетные записи» там, где появляется идентификатор отдела 100, и игнорировать остальные команды.
  4. Ни один из вышеперечисленных

Answer: D. Выражение CASE упрощает условную логику if-then-else. Есть два варианта выражения CASE. Простое выражение CASE перечисляет элемент условного поиска один раз, и равенство элементу поиска проверяется каждым выражением сравнения. В искомом выражении CASE указано отдельное условие для каждого выражения сравнения.

91. What is the maximum number of WHENÖTHEN levels a CASE statement in Oracle DB can have?

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

Answer: D.

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

SELECT NVL2(
       NULLIF ('BMW','AUDI'),
       'HYUNDAI',
       'FERRARI'
       )
       FROM dual;
  1. BMW
  2. FERRARI
  3. NULL
  4. HYUNDAI

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

93. Assuming the SYSDATE is 01-JAN-13 , what will the following query yield?

SELECT TO_CHAR (sysdate, 'fmddth" of" Month YYYY') FROM dual;
  1. 1 января 2013 г.
  2. 1 января 2013 г.
  3. 01 января 2013 г.
  4. 1 января 2013 г.

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

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

SELECT TO_CHAR (TO_DATE('01-JAN-13','DD-MON-YY'), 'MmSP Month Yyyysp') FROM dual;
  1. Первое января две тысячи тринадцатого года
  2. Первое ЯНВАРЬ две тысячи тринадцать
  3. Одно января две тысячи тринадцатого года
  4. Ни один из вышеперечисленных

Answer: C.

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

SELECT TO_CHAR (TO_DATE('01-JAN-13','DD-MON-YY'), 'DD-MON-YYYY hh24SpTh') FROM dual;
  1. Первое января две тысячи тринадцатого года
  2. Одно января две тысячи тринадцатого года
  3. Ошибка ORA
  4. 01-ЯНВ-2013 нулевые

Answer: D. Компонент timestamp можно указать с помощью модификатора формата SpTh.

96. Which of these functions do the work similar to if-then-else logic in SQL statements?

  1. TO_CHAR
  2. TO_NUMBER
  3. Оба а и Б
  4. CASE

Answer: D. Выражение CASE упрощает условную логику if-then-else. Есть два варианта выражения CASE. Простое выражение CASE перечисляет элемент условного поиска один раз, и равенство элементу поиска проверяется каждым выражением сравнения. В искомом выражении CASE указано отдельное условие для каждого выражения сравнения.

97. Examine the structure of the EMPLOYEES table 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-запроса?

SELECT DECODE (salary,10000) FROM employees;
  1. 10000
  2. NULL
  3. 0
  4. Ошибка ORA

Answer: B. Функция DECODE реализует условную логику if-then-else, проверяя свои первые два члена на равенство и возвращает третий член, если они равны, и, при необходимости, возвращает другой член, если это не так. Функция DECODE принимает как минимум три обязательных параметра, но может принимать намного больше. Если значение по умолчанию в функции DECODE опущено, возвращается NULL.

98. You need to display the time of the Oracle DB session up to 3 decimal places of the fractional seconds. Which of the following queries will give the required output?

  1. SELECT TO_CHAR(sysdate, 'DD-MON-YY HH24:MI:SS.FF') FROM dual;
  2. SELECT TO_CHAR(sysdate, 'DD-MON-YY HH24:MI:SS') FROM dual;
  3. SELECT TO_CHAR(sysdate, 'DD-MON-YY HH24:MI:SS.FF3') FROM dual;
  4. SELECT TO_CHAR(sysdate, 'DD-MON-YY') FROM dual;

Answer: C. Расширение FF [1..9] формата HH: MI: SS дает дробные секунды до 1..9 цифр в долях секунды.

99. Which of the following punctuation marks can be used with Dates and Times in Oracle DB?

  1. #
  2. @
  3. ,
  4. :

Answer: C, D.

100. Examine the structure of the EMPLOYEES table 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)

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

  1. SELECT TO_CHAR(hire_date, 'DDD') FROM employees WHERE last_name = 'Patrick' AND first_name = 'John';
  2. SELECT TO_CHAR(hire_date, 'YYYY') FROM employees WHERE last_name = 'Patrick' AND first_name = 'John';
  3. SELECT TO_CHAR(hire_date, 'DD-MON-YYYY') FROM employees WHERE last_name = 'Patrick' AND first_name = 'John';
  4. SELECT TO_CHAR(hire_date, 'DD-MON-RR') FROM employees WHERE last_name = 'Patrick' AND first_name = 'John';

Answer: A. Модель формата «DDD» возвращает день года, на который приходится указанная дата.

101. A report is required to be generated which gives the timings for all the batch runs that started on midnight 1st June, 2013. These timings should be in the precision of seconds after midnight. Which of the following clauses will fulfill the requirement?

  1. TO_CHAR(sysdate,'HH24:MI:SS')
  2. TO_CHAR(sysdate,'HH24:MI:SS.FF')
  3. TO_CHAR(sysdate,'HH24:MI:SSSS')
  4. TO_CHAR(sysdate,'HH24:MI:SS.FF3')

Answer: C. модель формата «SSSS» дает секунды после полуночи.