Вопросы о функциях преобразования

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

SELECT ROUND(144.23,-1) FROM dual;
  1. 140
  2. 144
  3. 150
  4. 100

Answer: A. Функция ROUND округляет значение 144,23 в соответствии с указанной точностью -1 и возвращает 140.

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

2. You are currently located in New Jersey and have connected to a remote database in San Diego. You issue the following command.

SELECT ROUND (sysdate-hire_date,0) FROM employees WHERE (sysdate-hire_date)/180 = 2;

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

  1. Ошибка из-за невозможности использования функции ROUND с аргументами Date.
  2. Ошибка из-за недопустимого выражения условия WHERE.
  3. Количество дней с момента приема на работу сотрудника на основе текущей даты и времени Сан-Диего.
  4. Количество дней с момента приема на работу сотрудника с учетом текущей даты и времени в Нью-Джерси.

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

3. You need to display the names of the employees who have the letter 's' in their first name and the letter 't' at the second position in their last name. Which query would give the required output?

  1. SELECT first_name, last_name FROM employees WHERE INSTR(first_name,'s') <> 0 AND SUBSTR(last_name,2,1) = 't';
  2. SELECT first_name, last_name FROM employees WHERE INSTR(first_name,'s') <> '' AND SUBSTR(last_name,2,1) = 't';
  3. SELECT first_name, last_name FROM employees WHERE INSTR(first_name,'e') IS NOT NULL AND SUBSTR(last_name,2,1) = 't';
  4. SELECT first_name, last_name FROM employees WHERE INSTR(first_name,'e') <> 0 AND SUBSTR(last_name,LENGTH(first_name),1) =  
    't';

Answer: A.Функция INSTR возвращает позицию данного символа в требуемой строке. Функция SUBSTR возвращает набор символов из строки с заданной начальной и конечной позиции.

4. Which of the following statements is true regarding the COUNT function?

  1. COUNT (*) подсчитывает повторяющиеся значения и значения NULL в столбцах любого типа данных.
  2. Функция COUNT не может работать с типами данных DATE.
  3. COUNT (DISTINCT job_id) возвращает количество строк, исключая строки, содержащие дубликаты, и значения NULL в столбце job_id.
  4. Оператор SELECT, использующий функцию COUNT с ключевым словом DISTINCT, не может иметь предложение WHERE.

Answer: A.Функция COUNT (*) возвращает количество строк в таблице, удовлетворяющих критериям оператора SELECT, включая повторяющиеся строки и строки, содержащие нулевые значения в любом из столбцов. Если предложение WHERE включено в оператор SELECT, COUNT (*) возвращает количество строк, удовлетворяющих условию в предложении WHERE. Напротив, COUNT (expr) возвращает количество ненулевых значений, которые находятся в столбце, идентифицированном expr. COUNT (DISTINCT expr) возвращает количество уникальных ненулевых значений, которые находятся в столбце, идентифицированном expr.

5. Which of the following commands is used to count the number of rows and non-NULL values in Oracle database?

  1. НЕНУЛЕВОЙ
  2. INSTR
  3. SUBSTR
  4. COUNT

Answer: D.COUNT (ALL column_name) используется для подсчета количества строк, исключая NULL. Точно так же COUNT (*) используется для подсчета значений столбца, включая NULL.

6. What will be the outcome of the query given below?

SELECT 100+NULL+999 FROM dual;
  1. 100
  2. 999
  3. NULL
  4. 1099

Answer: C. Любая арифметическая операция с NULL приводит к NULL.

7. Which of the following statements are true regarding the single row functions?

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

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

8. Which of the below queries will format a value 1680 as $16,80.00?

  1. SELECT TO_CHAR(1680.00,'$99G99D99') FROM dual;
  2. SELECT TO_CHAR(1680.00,'$9,999V99') FROM dual;
  3. SELECT TO_CHAR(1680.00,'$9,999D99') FROM dual;
  4. SELECT TO_CHAR(1680.00,'$99G999D99') FROM dual;

Answer: A, D. Модель формата $ 99G999D99 форматирует заданное число в числовое, с разделителем групп и десятичными знаками. Другие элементы формата могут быть ведущими нулями, десятичной позицией, позицией запятой, местной валютой, экспоненциальным представлением и знаком.

9. Determine the output of the below query.

SELECT RPAD(ROUND('78945.45'),10,'*') FROM dual;
  1. 78945*****
  2. **78945.45
  3. Функция RPAD не может быть вложена в другие функции.
  4. 78945.45****

Answer: A. Функции LPAD (строка, число, символ) и RPAD (строка, число, символ) добавляют символ слева или справа от заданной строки до тех пор, пока он не достигнет указанной длины (числа) после заполнения. Функция ROUND округляет значение 78945,45 до 78945, а затем дополняет его знаком «*», пока не будет достигнута длина 10.

10. Which of the following commands allows you to substitute a value whenever a NULL or non-NULL value is encountered in an SQL query?

  1. NVL
  2. NVLIF
  3. NVL2
  4. LNNVL

Answer: C. Функция NVL2 принимает минимум три аргумента. Функция NVL2 проверяет первое выражение. Если он не равен нулю, функция NVL2 возвращает второй аргумент. Если первый аргумент равен нулю, возвращается третий аргумент.

11. Which of the following type of single-row functions cannot be incorporated in Oracle DB?

  1. Character
  2. Numeric
  3. Conversion
  4. Ни один из вышеперечисленных

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

12. Out of the below clauses, where can the single-row functions be used?

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

Answer: D. Однострочную функцию можно использовать в операторе SELECT, предложении WHERE и ORDER BY.

13. What is true regarding the NVL function in Oracle DB?

  1. Синтаксис NVL - NVL (exp1, exp2), где exp1 и exp2 - выражения.
  2. NVL (exp1, exp2) вернет значение exp2, если выражение exp1 равно NULL.
  3. NVL (exp1, exp2) вернет значение выражения exp2, если exp1 НЕ ПУСТО.
  4. NVL (exp1, exp2) вернет exp1, если выражение exp2 равно NULL.

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

14. 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 last_name, NVL(job_id, 'Unknown') 
FROM employees
WHERE last_name LIKE 'A%'
ORDER BY last_name;
  1. При выполнении будет выдана ошибка ORA.
  2. В нем будут перечислены идентификаторы вакансий для всех сотрудников из таблицы EMPLOYEES.
  3. Он перечислит идентификаторы вакансий всех сотрудников и заменит NULL идентификаторы вакансий на буквальное значение «Неизвестно».
  4. Он будет отображать фамилии всех сотрудников и их идентификаторы должностей, включая значения NULL в идентификаторе вакансии.

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

15. What will the outcome of the following query?

SELECT NVL (NULL,'1') FROM dual;
  1. NULL
  2. 1
  3. 0
  4. Выдает ошибку, потому что NULL нельзя явно указать для функции NVL

Answer: B. NVL будет рассматривать NULL как значение и в качестве результата вернет альтернативный аргумент, то есть 1.

16. What will be the outcome of the following query? (Consider 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 employee_id , NVL(salary, 0) FROM employees WHERE first_name like 'P%' ORDER BY first_name;
  1. В столбце зарплаты для всех сотрудников, имя которых начинается с буквы «P», будет отображаться 0.
  2. Он будет отображать зарплаты для сотрудников, имена которых начинаются с буквы «P» и 0, если зарплаты равны NULL.
  3. Это вызовет ошибку ORA, поскольку предложение ORDER BY также должно содержать столбец зарплаты.
  4. Функцию NVL следует правильно использовать как NVL (0, зарплата)

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

17. Which of the following statements is true regarding the NVL statement?

SELECT NVL (arg1, arg2) FROM dual;
  1. Два выражения arg1 и arg2 должны быть только в формате данных VARCHAR2 или NUMBER.
  2. Аргументы arg1 и arg2 должны иметь одинаковый тип данных.
  3. Если arg1 равен VARCHAR2, то Oracle DB преобразует arg2 в тип данных arg1 перед их сравнением и возвращает VARCHAR2 в наборе символов arg1.
  4. Функцию NVL нельзя использовать с аргументами типа DATE.

Answer: C. Если arg1 имеет тип данных VARCHAR2, Oracle выполняет неявное преобразование типа для arg2 id arg2 имеет тип данных NUMBER. Во всех остальных случаях оба аргумента должны иметь один и тот же тип данных.

18. What will be the outcome of the following query? (Consider 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 NVL2(job_id,'Regular Employee','New Joinee') FROM employees;
  1. Он вернет значение «Обычный сотрудник» для всех сотрудников, у которых есть NULL идентификаторы вакансий.
  2. Он вернет значение New Joinee для всех сотрудников, у которых есть NULL идентификаторы вакансий.
  3. Он вернет «Обычный сотрудник», если идентификатор задания равен NULL.
  4. При выполнении будет выдана ошибка ORA.

Answer: B. Функция NVL2 проверяет первое выражение. Если первое выражение не равно нулю, функция NVL2 возвращает второе выражение. Если первое выражение имеет значение NULL, возвращается третье выражение.

19. Which of the following is true for the statement given as under.

NVL2 (arg1, arg2, arg3)
  1. Arg2 и Arg3 могут иметь любой тип данных
  2. Arg1 не может иметь тип данных LONG
  3. Oracle преобразует тип данных expr2 в соответствии с Arg1
  4. Если Arg2 - это ЧИСЛО, то Oracle определяет числовой приоритет, неявно преобразует другой аргумент в этот тип данных и возвращает этот тип данных.

Answer: D. Типы данных параметров arg2 и arg3 должны быть совместимыми, и они не могут быть типа LONG. Они должны быть одного типа или должна иметься возможность преобразовать arg3 в тип параметра arg2. Тип данных, возвращаемый функцией NVL2, такой же, как и у параметра arg2.

20. 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, NVL2(commission_pct,  salary + (salary * commission_pct), salary) "Income" 
FROM employees 
WHERE first_name like 'P%'  
ORDER BY first_name;
  1. Заработная плата будет возвращена, если комиссия для сотрудника НЕ ​​НУЛЕВАЯ.
  2. Commission_pct будет возвращена, если Комиссия для сотрудника НЕ ​​НУЛЕВАЯ.
  3. Сотрудники, имена которых начинаются с буквы «P», и зарплата + (зарплата * комиссия_пц) будут возвращены, если сотрудник получает комиссию.
  4. Запрос выдает ошибку, потому что математическое выражение записано внутри NVL2.

Answer: C. Функция NVL2 проверяет первое выражение. Если первое выражение не равно нулю, функция NVL2 возвращает второе выражение. Если первое выражение имеет значение NULL, возвращается третье выражение.

21. What is true about the NULLIF function in Oracle DB?

  1. NULLIF (expr1, expr2) вернет expr2, если два выражения NOT NULL.
  2. NULLIF (expr1, expr2) вернет 0, если два выражения NULL.
  3. NULLIF (expr1, expr2) вернет NULL, если два выражения равны.
  4. Expr1 может быть NULL в NULLIF (expr1, expr2)

Answer: C. Функция NULLIF проверяет два условия на равенство. Если они равны, функция возвращает нуль, в противном случае она возвращает первый из двух проверенных терминов. Функция NULLIF принимает два обязательных параметра любого типа данных. Синтаксис - NULLIF (arg1, arg2), где сравниваются аргументы arg1 и arg2. Если они идентичны, возвращается NULL. Если они отличаются, возвращается arg1.

22. Pick the correct answer given after the statement shown as under.

NULLIF (arg1,arg2)
  1. Arg1 и Arg2 могут иметь разные типы данных.
  2. Arg1 и Arg2 должны быть равны, чтобы их можно было использовать в функции NULLIF.
  3. Если используется NULLIF, как в случае NVL и NVL2, внутреннего преобразования типов данных не происходит.
  4. Это эквивалентно CASE WHEN Arg1 = Arg22 THEN NULL ELSE Arg1 END.

Answer: D.

23. 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)

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

SELECT e.last_name, NULLIF(e.job_id, j.job_id,"Old Job ID")  
FROM employees e, job_history j  
WHERE e.employee_id = j.employee_id  
ORDER BY last_name;

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

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

Answer: B.

24. Which of the following is not a property of functions?

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

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

25. What is the most appropriate about single row functions?

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

Answer: B. Однострочные функции всегда возвращают один результат для каждой строки и работают только с отдельными строками; отсюда и название «Однорядный».

26. What among the following is a type of Oracle SQL functions?

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

Answer: A. В основном есть два типа функций - функции с одной строкой и с несколькими строками.

27. What among the following is a type of single-row function?

  1. VARCHAR2
  2. Character
  3. LONG
  4. NULLIF

Answer: B. Символьный, Дата, Преобразование, Общее, Число - это типы однорядных функций.

28. What is the most appropriate about Multiple Row Functions?

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

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

29. Which of the following are also called Group functions?

  1. Однострочные функции
  2. Многогрупповые функции
  3. Многострочные функции
  4. Одиночные групповые функции.

Answer: C. Групповые функции такие же, как многострочные функции и агрегатные функции.

30. Which of the following is true about Single Row Functions?

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

Answer: A. Однострочные функции могут иметь несколько уровней вложенности.

31. What is the number of arguments Single Row functions accept?

  1. 0
  2. Только 1
  3. Только 2
  4. 1 или более 1

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

32. Which of the following can be an argument for a Single Row Function?

  1. Типы данных
  2. Операторы SELECT
  3. Expression
  4. Имя таблицы

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

33. What is true about Character functions?

  1. Они возвращают только символьные значения
  2. Они принимают ЧИСЛО значений
  3. Они принимают символьные аргументы и могут возвращать как символьные, так и числовые значения.
  4. Они принимают значения всех типов данных

Answer: C. Символьная функция INSTR принимает строковое значение, но возвращает числовую позицию символа в строке.

34. What is true about Number functions?

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

Answer: D.

35. Which of the following is an exception to the return value of a DATE type single-row function?

  1. TO_DATE
  2. SYSDATE
  3. MONTHS_BETWEEN
  4. TO_NUMBER

Answer: C. Все функции типа данных DATE возвращают DATE в качестве возвращаемых значений, кроме MONTHS_BETWEEN, который возвращает число.

36. Which of the following is not a Conversion type Single Row function?

  1. TO_CHAR
  2. TO_DATE
  3. NVL
  4. TO_NUMBER

Answer: C. Функции преобразования преобразуют значение из одного типа данных в другой. Функция NVL заменяет нулевое значение альтернативным значением.

37. Which of the following is a Case-Conversion Character function?

  1. CONCAT
  2. SUBSTR
  3. INITCAP
  4. REPLACE

Answer: C. CONCAT, SUBSTR и REPLACE - это символьные функции манипулирования символами, а INITCAP, LOWER и UPPER - символьные функции преобразования регистра.

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

SELECT lower('HI WORLD !!!')  FROM dual;
  1. Привет, мир !!!
  2. Привет, мир !!!
  3. Привет, мир !!!
  4. ПРИВЕТ, МИР !!!

Answer: C. Функция LOWER преобразует строку в символы нижнего регистра.

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

SELECT lower(upper(initcap('Hello World') )) FROM dual;
  1. Привет, мир
  2. Привет, мир
  3. Привет, мир
  4. Привет, мир

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

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

40. Which of the following queries will give the same result as given in the query given below?

SELECT CONCAT(first_name, last_name) FROM employees;
  1. ВЫБЕРИТЕ first_name || last_name ИЗ сотрудников;
  2. ВЫБЕРИТЕ first_name || ' '|| last_name ОТ сотрудников;
  3. ВЫБЕРИТЕ last_name || ',' || first_name ИЗ сотрудников;
  4. ВЫБЕРИТЕ first_name || ',' || last_name ИЗ сотрудников;

Answer: A. Функция CONCAT объединяет две строки без пробелов между ними.

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

SELECT 'The job id for '||upper(last_name) ||' is a '||lower(job_id) FROM employees;
  1. Идентификатор вакансии для ABEL - sa_rep
  2. Идентификатор вакансии для ABEL - sa_rep
  3. Идентификатор вакансии для abel - SA_REP
  4. Идентификатор вакансии для abel - sa_rep

Answer: A.

42. Assuming the last names of the employees are in a proper case in the table employees, what will be the outcome of the following query?

SELECT employee_id, last_name, department_id  FROM employees WHERE last_name = 'smith';
  1. Будет отображена информация о сотруднике с фамилией Смит.
  2. Это не даст результата.
  3. Он предоставит сведения о сотруднике, чья фамилия «Смит» в нижнем регистре.
  4. В нем будут указаны сведения о сотруднике, имеющем фамилию «Смит» во всех случаях INITCAP.

Answer: B. Если фамилии в таблице сотрудников указаны в правильном регистре, условие WHERE last_name = 'smith' не будет выполнено, и, следовательно, результаты не будут отображаться.

43. What is true about the CONCAT function in Oracle DB?

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

Answer: B. Функция CONCAT принимает только два аргумента типа данных NUMBER или VARCHAR2.

44. What is true about the SUBSTR function in Oracle DB?

  1. Он извлекает строку определенной длины
  2. Он показывает длину строки как числовое значение
  3. Находит числовую позицию именованного символа
  4. Он обрезает символы с одной (или обеих) сторон строки символов.

Answer: A.Функция SUBSTR (строка, x, y) принимает три параметра и возвращает строку, состоящую из количества символов, извлеченных из исходной строки, начиная с указанной начальной позиции (x). Если позиция положительна, функция считает с начала строки, чтобы найти первый символ. Когда позиция отрицательная, функция ведет отсчет назад от конца строки.

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

SELECT length('hi') FROM dual;
  1. 2
  2. 3
  3. 1
  4. hi

Answer: A. функция LENGTH просто дает длину строки.

46. What is the difference between LENGTH and INSTR functions in Oracle DB?

  1. Они дают такие же результаты при работе со струной.
  2. ДЛИНА дает позицию определенного символа в строке
  3. INSTR дает позицию определенного символа в строке, а LENGTH дает длину строки.
  4. LENGTH и INSTR могут использоваться как взаимозаменяемые.

Answer: C.

47. 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 upper(&jobid) FROM employees;
  1. Это приводит к ошибке, поскольку переменные подстановки не могут использоваться с функциями одной строки.
  2. Он предлагает пользователю ввести идентификатор задания при каждом выполнении, а затем отображает идентификатор задания в ВЕРХНЕМ регистре.
  3. Он выдает jobid, как он присутствует в таблице EMPLOYEES, без каких-либо изменений.
  4. Он не будет просить пользователя ввести идентификатор задания и преобразует все идентификаторы заданий в таблице в ВЕРХНИЙ регистр.

Answer: B. Переменные подстановки можно использовать с функциями UPPER и LOWER.

48. What is false about the table DUAL in Oracle database?

  1. Он принадлежит пользователю SYS и может быть доступен всем пользователям.
  2. Он содержит только один столбец и одну строку.
  3. Значение в столбце DUMMY таблицы DUAL - 'X'.
  4. Таблица DUAL полезна, когда вы хотите вернуть значение только один раз

Answer: C. В таблице DUAL есть один столбец с именем DUMMY и одна строка со значением «X».

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

SELECT sysdate+4/12 FROM dual;
  1. Запрос вызывает ошибку.
  2. Нет часов до свидания с датой в результате.
  3. Арифметика Sysdate игнорируется.
  4. В качестве результата возвращает системную дату.

Answer: B. Арифметические операции могут выполняться с датами в базе данных Oracle.

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

SELECT lower (100+100) FROM dual;
  1. 100
  2. 100+100
  3. Ошибка ORA
  4. 200

Answer: D. Арифметические выражения могут быть указаны в функциях преобразования регистра.

51. What will be the outcome of the following query if the SYSDATE = 20-MAY-13?

SELECT upper (lower (sysdate)) FROM dual;
  1. 20-may-2013
  2. Ошибка ORA как LOWER и UPPER не может принимать значения даты.
  3. 20-MAY-13
  4. 20-May-13

Answer: C. Функции UPPER и LOWER могут принимать входные данные типа даты и дают тот же результат, что и для строк.

52. What is the result of the following query?

SELECT INITCAP (24/6) FROM dual;
  1. 4
  2. 24
  3. 24/6
  4. Безрезультатно

Answer: A. Арифметические выражения могут быть указаны в функциях преобразования регистра.

53. Examine the structure of the EMPLOYEES table as given here.

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

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

  1. SELECT INITCAP (last_name||' works as a '||job_id "Job Description" FROM employees WHERE initcap (last_name) like 'A%';
  2. SELECT INITCAP (last_name) ||INITCAP(' works as a: ')|| INITCAP(job_id) "Job Description" FROM employees WHERE initcap (last_name) like 'A 
    %';
  3. SELECT INITCAP (last_name||' works as a '||INITCAP(job_id)) "Job Description" FROM employees WHERE initcap (last_name) = 'A';
  4. SELECT UPPER (LOWER (last_name||' works as a '||job_id)) "Job Description" FROM employees WHERE lower (last_name) = 'A';

Answer: A, B.

54. Assuming the SYSDATE is 20-FEB-13, What will be the outcome of the following query?

SELECT CONCAT ('Today is :', SYSDATE) FROM dual;
  1. Сегодня: 20-фев-13
  2. Запрос выдает ошибку несовместимых аргументов типа.
  3. Сегодня: 20-фев-13
  4. Сегодня: 20-февр.

Answer: D. Функция CONCAT принимает аргументы всех типов.

55. What will be the result pattern of the following query?

SELECT CONCAT(first_name, CONCAT (last_name, job_id)) FROM dual;
  1. First_namelast_namejob_id
  2. First_name, last_name, job_id
  3. Ошибка, поскольку CONCAT не может быть вложенным
  4. First_namelast_name, job_id

Answer: A. Функция CONCAT может быть вложена с функцией self или другой символьной функцией.

56. Examine the structure of the EMPLOYEES table as given here.

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

Вам необходимо создать отчет, в котором будут указаны имя, фамилия и зарплата всех сотрудников отдела 100. Отчет должен отображать результаты в форме «Энди Смит зарабатывает 50000». Какой из следующих запросов даст требуемый результат?

  1. SELECT concat (first_name,concat (' ', concat(last_name, concat(' earns ', SALARY)))) Concat_String FROM employees WHERE department_id =  
    100;
  2. SELECT concat (first_name, last_name||' '|| salary) FROM employees WHERE department_id = 100;
  3. SELECT concat (first_name, concat(last_name, ' '))||earns||salary FROM employees WHERE department_id = 100;
  4. SELECT concat (first_name, concat(last_name, 'earns salary') FROM employees WHERE department_id = 100;

Answer: A. Функция CONCAT может быть вложена с функцией self или другой символьной функцией.

57. What will the following query show as a result?

SELECT LENGTH('It is a lovely day today!') FROM dual;
  1. 25
  2. 19
  3. 20
  4. 0

Answer: A. Функция LENGTH также считает пробелы, табуляции и специальные символы.

58. You need to display the country name from the COUNTRIES table. The length of the country name should be greater than 5 characters. Which of the following queries will give the required output?

  1. SELECT country_name FROM countries WHERE LENGTH (country_name)= 5;
  2. SELECT country_name FROM countries WHERE length (country_name)> 5;
  3. SELECT SUBSTR(country_name, 1,5) FROM countries WHERE length (country_name)< 5;
  4. SELECT country_name FROM countries WHERE length (country_name) <> 5;

Answer: B. Функцию LENGTH можно использовать в предложении WHERE.

59. How does the function LPAD works on strings?

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

Answer: D. Функции LPAD (строка, длина после заполнения, строка заполнения) и RPAD (строка, длина после заполнения, строка заполнения) добавляют строку заполнения символов слева или справа от строки, пока она не достигнет указанной длины после заполнения.

60. Which of the following options is true regarding LPAD and RPAD functions?

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

Answer: D.

61. What is the maximum number of input arguments in LPAD and RPAD functions?

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

Answer: C. LPAD и RPAD принимают максимум 3 аргумента. Если указано 2 аргумента, заполнение выполняется пробелами.

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

SELECT lpad (1000 +300.66, 14, '*') FROM dual;
  1. *******1300.66
  2. 1300*******
  3. 1300.66
  4. ****1300.66

Answer: A. Чтобы общая длина составляла 14 символов, возвращаемое значение 1300.66 дополняется 7 звездочками (*) слева.

63. What is true regarding the TRIM function?

  1. Это похоже на функцию SUBSTR в Oracle
  2. Удаляет символы из начала или конца символьных литералов, столбцов или выражений.
  3. Функция ОБРЕЗАТЬ не может применяться к выражениям и ЧИСЛАМ
  4. Функция TRIM может удалять символы только с обеих сторон строки.

Answer: B. Функция TRIM буквально обрезает начальные или конечные (или обе) строки символов из данной исходной строки. Функция TRIM, за которой следуют ключевые слова TRAILING или LEADING, может удалять символы с одной или обеих сторон строки.

64. You need to remove the occurrences of the character '.' and the double quotes '"' from the following titles of a book present in the table MAGAZINE.

"HUNTING THOREAU IN NEW HAMPSHIRE" THE ETHNIC NEIGHBORHOOD."

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

  1. SELECT LTRIM(Title,'"') FROM MAGAZINE;
  2. SELECT LTRIM(RTRIM(Title,'."'),'"') FROM MAGAZINE;
  3. SELECT LTRIM (Title,'"THE') FROM MAGAZINE;
  4. SELECT LTRIM(RTRIM(Title,'."THE'),'"') FROM MAGAZINE;

Answer: B. Функции LTRIM и RTRIM можно использовать в сочетании друг с другом.

65. What will be returned as a result of the following query?

SELECT INSTR('James','x') FROM dual;
  1. 1
  2. 2
  3. 0
  4. 3

Answer: C. Функция INSTR возвращает 0, если строка поиска отсутствует в данной строке.

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

SELECT INSTR('1$3$5$7$9$','$',3,4)FROM dual;
  1. 2
  2. 10
  3. 7
  4. 4

Answer: B. Функция INSTR ищет 4-е вхождение символа '$', начиная с 3-й позиции.

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

SELECT INSTR('1#3#5#7#9#', -3,2) FROM dual;
  1. #5
  2. #3
  3. #7
  4. #9

Answer: D. Функция SUBSTR выполнит поиск в 3 местах, начиная с конца строки, и выдаст 2 символа в прямом направлении, что дает # 9.

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

68. You need to extract a consistent 15 character string based on the SALARY column in the EMPLOYEES table. If the SALARY value is less than 15 characters long, zeros must be added to the left of the value to yield a 15 character string. Which query will fulfill this requirement?

  1. SELECT rpad(salary, 15,0) FROM employees;
  2. SELECT lpad(salary,15,0) FROM employees;
  3. SELECT ltrim(salary,15,0) FROM employees;
  4. SELECT trim(salary,15,0) FROM employees;

Answer: B. Функции LPAD и RPAD добавляют строку символов слева или справа от строки, пока она не достигнет указанной длины после заполнения.

69. You need to display the last 2 characters from the FIRST_NAME column in the EMPLOYEES table without using the LENGTH function. Which of the following queries can fulfill this requirement?

  1. SELECT SUBSTR(first_name, 2) FROM employees;
  2. SELECT SUBSTR(first_name, -2) FROM employees;
  3. SELECT RTRIM(first_name, 2) FROM employees;
  4. SELECT TRIM(first_name, 2) FROM employees;

Answer: B. Функция SUBSTR (строка, x, y) принимает три параметра и возвращает строку, состоящую из количества символов, извлеченных из исходной строки, начиная с указанной начальной позиции (x). Если позиция положительна, функция считает с начала строки, чтобы найти первый символ. Когда позиция отрицательная, функция ведет отсчет назад от конца строки.

70. Assuming the SYSDATE is 13-JUN-13, what will be the outcome of the following query?

SELECT SUBSTR(sysdate,10,7) FROM dual;
  1. 3
  2. N-13
  3. 0
  4. NULL

Answer: D. Запрос вернет NULL, поскольку позиция 10 для начала в SYSDATE не существует.

71. Which of the following is used to replace a specific character in a given string in Oracle DB?

  1. LTRIM
  2. TRIM
  3. TRUNC
  4. REPLACE

Answer: D.

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

SELECT replace(9999.00-1,'8',88) FROM dual;
  1. 999
  2. 9998
  3. 99988
  4. 9999.88

Answer: C. Функция REPLACE выполняет поиск «8» в 9998 и заменяет его на «88».

73. Examine the structure of the EMPLOYEES table as given here.

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

Вам необходимо получить имя, фамилию (разделенные пробелом) и официальные имена сотрудников, у которых общая длина имени и фамилии превышает 15 символов. Формальное имя состоит из первой буквы имени и первых 14 символов фамилии. Какой из следующих запросов соответствует этому требованию?

  1. SELECT first_name, last_name ,SUBSTR(first_name, 1,1)||' '||SUBSTR(last_name, 1,14) formal_name FROM employees;
  2. SELECT first_name, last_name ,SUBSTR(first_name, 1,14)||' '||SUBSTR(last_name, 1,1) formal_name FROM employees WHERE length 
    (first_name) + length(last_name) < 15;
  3. SELECT first_name, last_name ,SUBSTR(first_name, 1,1)||' '||SUBSTR(last_name, 1,14) formal_name FROM employees WHERE length 
    (first_name) + length(last_name) =15;
  4. SELECT first_name, last_name ,SUBSTR(first_name, 1,1)||' '||SUBSTR(last_name, 1,14) formal_name FROM employees WHERE length 
    (first_name) + length(last_name) > 15;

Answer: D.

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

SELECT round(148.50) FROM dual;
  1. 148.50
  2. 140
  3. 150
  4. 149

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

75. Assuming the sysdate is 10-JUN-13, What will be the outcome of the following query?

SELECT trunc (sysdate,'mon') FROM dual;
  1. 10-JUN-13
  2. 1-JUN-13
  3. Ошибка ORA, поскольку функция TRUNC не может иметь входной параметр при использовании с датами.
  4. 31-JUN-13

Answer: B. Дата обрезается до первого дня месяца. Точно так же это можно сделать и за год.

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

SELECT trunc(1902.92,-3) FROM dual;
  1. 2000
  2. 1000
  3. 1901
  4. 1901.00

Answer: B.

77. What is the syntax of the MOD function in Oracle DB?

  1. Mod(divisor,dividend)
  2. MOD(divisor,1)
  3. MOD(dividend,divisor)
  4. Ни один из вышеперечисленных

Answer: C. Функция MOD используется для получения остатка от операции деления.

78. What will be outcome of the following query?

SELECT mod(100.23,-3) FROM dual;
  1. Ошибка ORA
  2. 1.23
  3. 100
  4. 0

Answer: B. Функция MOD дает одинаковый ответ как для положительного, так и для отрицательного делителя.

79. Which of the following functions are used to differentiate between even or odd numbers in Oracle DB?

  1. ROUND
  2. TRUNC
  3. MOD
  4. REPLACE

Answer: C. Функцию MOD можно использовать, чтобы проверить, является ли данное число четным или нечетным. Если MOD (num, 2) возвращает ноль, число num является четным. Если MOD (num, 2) возвращает 1, число num нечетное.

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

Вам необходимо распределить первых 12 сотрудников в одну из четырех команд циклическим способом. Идентификаторы сотрудников начинаются со 100. Какой из следующих запросов будет соответствовать требованию?

  1. SELECT * FROM employees WHERE employee_id between 100 and 111 ORDER BY employee_id;
  2. SELECT first_name, last_name, employee_id, mod(employee_id, 4) Team# FROM employees WHERE employee_id between 100 and 111  
    ORDER BY employee_id;
  3. SELECT first_name, last_name,mod(employee_id, 2) Team# FROM employees WHERE employee_ID <> 100;
  4. SELECT first_name, last_name, mod(employee_id, 4) Team# FROM employees WHERE employee_ID = 100;

Answer: B.

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

SELECT SUBSTR('Life is Calling',1) FROM dual;
  1. Ошибка ORA, так как у функции SUBSTR должно быть минимум 3 аргумента.
  2. Жизнь зовет
  3. NULL
  4. Life

Answer: B. Вызов функции SUBSTR только с первыми двумя параметрами приводит к тому, что функция извлекает строку от начальной позиции до конца данной исходной строки.

82. What is the default data format for the sysdate in SQL Developer?

  1. DD-MON-YY
  2. DD-MON-RR
  3. DD/MON/RR
  4. DD/MON/YYYY

Answer: C. Для SQL * PLUS формат даты по умолчанию - DD-MON-RR.

83. Assuming the SYSDATE to be 10-JUN-2013 12:05pm, what value is returned after executing the below query?

SELECT add_months(sysdate,-1) FROM dual;
  1. 09 МАЯ 2013 12:05
  2. 10 МАЯ 2013 12:05
  3. 10-ИЮЛ-2013 12:05
  4. 09-ИЮЛ-2013 12:05

Answer: B. Функция ADD_MONTHS (date, x) добавляет к заданной дате количество календарных месяцев 'x'. Значение «x» должно быть целым числом и может быть отрицательным.

84. What value will be returned after executing the following statement? Note that 01-JAN-2013 occurs on a Tuesday.

SELECT next_day('01-JAN-2013','friday') FROM dual;
  1. 02-JAN-2013
  2. Friday
  3. 04-JAN-2013
  4. Ни один из вышеперечисленных

Answer: C. NEXT_DAY (date, 'day') находит дату следующего указанного дня недели ('day'), следующего за датой. Значение char может быть числом, представляющим день, или символьной строкой.

85. What is the maximum number of parameters the ROUND function can take?

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

Answer: C. Если присутствует только один параметр, округление происходит до ближайшего целого числа.

86. Assuming the present date is 02-JUN-2007, what will be the century returned for the date 24-JUL-2004 in the DD-MON-RR format?

  1. 19
  2. 21
  3. 20
  4. NULL

Answer: C. Если две цифры текущего года и указанного года лежат между 0 и 49, возвращается текущий век.

87. Assuming the present date is 02-JUN-2007, what will be the century returned for the date 24-JUL-94 in the DD-MON-RR format?

  1. 19
  2. 21
  3. 20
  4. NULL

Answer: A. Если две цифры текущего года лежат между 0 и 49, а указанный год находится между 50 и 99, возвращается предыдущий век.

88. Assuming the present date is 02-JUN-1975, what will be the century returned for the date 24-JUL-94 in the DD-MON-RR format?

  1. 19
  2. 21
  3. 20
  4. NULL

Answer: A. если две цифры текущего и указанного года лежат между 50 и 99, по умолчанию возвращается текущий век.

89. Assuming the present date is 02-JUN-1975, what will be the century returned for the date 24-JUL-07 in the DD-MON-RR format?

  1. 19
  2. 21
  3. 20
  4. NULL

Answer: C. если две цифры текущего года лежат между 50 и 99, а указанный год находится между 0 и 49, возвращается следующий век.

90. How many parameters does the SYSDATE function take?

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

Answer: D. SYSDATE - это псевдостолбец в Oracle.

91. What is true about the SYSDATE function in Oracle DB?

  1. Возвращает только системную дату
  2. Требуется минимум 2 параметра.
  3. Формат по умолчанию - ДД-МЕС-ГГ.
  4. Формат SYSDATE по умолчанию - DD-MON-RR, и он возвращает дату и время системы в соответствии с сервером базы данных.

Answer: D.

92. What will be the datatype of the result of the following operation?

  1. Date
  2. Num1
  3. 0
  4. NULL

Answer: B. Вычитание двух дат дает количество дней.

93. What will be the datatype of the result of the following operation?

  1. Date
  2. Num1
  3. 0
  4. NULL

Answer: A. Вычитание числа из значения даты приводит к дате.

94. What does a difference between two dates represent in Oracle DB?

  1. Количество дней между ними
  2. Разница в датах невозможна в Oracle DB
  3. Свидание
  4. NULL

Answer: A.

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

SELECT months_between('21-JUN-13','19-JUN-13') FROM dual;
  1. Ошибка ORA
  2. Положительное число
  3. Отрицательное число
  4. 0

Answer: C. Если первый параметр меньше второго, MONTHS_BETWEEN возвращает отрицательное число.

96. What can be deduced if the result of MONTHS_BETWEEN (start_date,end_date) function is a fraction?

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

Answer: D.

97. You are connected to a remote database in Switzerland from India. You need to find the Indian local time from the DB. Which of the following will give the required result?

  1. SELECT sysdate FROM dual;
  2. SELECT round(sysdate) FROM dual;
  3. SELECT trunc (sysdate) FROM dual;
  4. SELECT current_date FROM dual;

Answer: D.

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

SELECT months_between (to_date ('29-feb-2008'), to_date ('29-feb-2008 12:00:00','dd-mon-yyyy hh24:mi:ss'))*31 FROM dual;
  1. Примерно 0
  2. 1
  3. Запрос выдаст ошибку ORA
  4. 0,5 дня

Answer: D. MONTHS_BETWEEN (date1, date2) находит количество месяцев между date1 и date2. Результат может быть положительным или отрицательным. Если date1 позже date2, результат будет положительным; если date1 раньше date2, результат будет отрицательным. Нецелая часть результата представляет собой часть месяца.

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

SELECT add_months ('31-dec-2008',2.5) FROM dual;
  1. 31-feb-2009
  2. 28-feb-2009
  3. 31-mar-2009
  4. 15-jan-2009

Answer: B. дробная часть 2,5 будет проигнорирована, и 2 месяца будут добавлены к 31-декабрь-2012, то есть 31-фев-2013, но, поскольку это недействительная дата, результат будет 28-фев-2009.

100. You need to identify the date in November when the staff will be paid. Bonuses are paid on the last Friday in November. Which of the following will fulfill the requirement?

  1. SELECT next_day ('30-nov-2012' , 'Friday') FROM dual;
  2. SELECT next_day ('30-nov-2012' , 'Friday') -7 FROM dual;
  3. SELECT last_day ('01-nov-2012' ) FROM dual;
  4. SELECT next_day ('30-nov-2012' , 'sat') -1 FROM dual;

Answer: B. Функции NEXT_DAY (дата, 'день') и LAST_DAY (дата, 'день') находят дату следующего или последнего указанного дня недели ('дня'), следующего за датой. Значение char может быть числом, представляющим день, или символьной строкой.