Preguntas sobre expresiones condicionales
1. What is true about data types in Oracle DB?
- Se asignan a las columnas con fines de clasificación.
- Se dan a columnas para una representación estructurada en una tabla.
- Se asignan a las columnas para restringir la naturaleza de los datos que puede almacenar.
- No son obligatorios.
Answer: C. Los tipos de datos definen la naturaleza de los datos que una columna puede almacenar en una tabla. Una columna puede almacenar solo un tipo de datos. Los tipos de datos principales disponibles en Oracle son NUMBER, VARCHAR2 y DATE.
2. What is true about nested functions?
- Existe un límite para usar las funciones anidadas solo 5 veces en Oracle DB.
- Se evalúan desde el nivel más externo hasta el nivel más interno.
- Se evalúan desde el nivel más interno hasta el nivel más externo.
- Todas las funciones de una expresión anidada devuelven el mismo tipo de datos.
Answer: C. Las funciones de una sola fila pueden agrupar funciones que se pueden anidar en una consulta SELECT en la que la función más interna es la primera en ejecutarse. El resultado de la ejecución de la función más interna sirve como entrada para la función externa.
3. Which of the following functions simplify working with columns that potentially contain null values?
- Funciones anidadas
- Funciones generales
- Funciones condicionales
- Ninguna de las anteriores
Answer: B. Las funciones generales como NVL, NVL2, NULLIF y COALESCE se utilizan para pacificar el efecto de NULL mientras se muestran los resultados de la consulta. Omiten los valores NULL asignando un valor alternativo.
4. Which of the following data types are appropriate for general functions?
- VARCHAR2
- NUMBER
- DATE
- Todos los tipos de datos
Answer: D. Las funciones generales suelen ser compatibles con todos los tipos de datos primarios como NUMBER, VARCHAR2 y DATE.
5. What is true about the COALESCE function?
- Acepta mínimo 2 y máximo 5 parámetros de entrada
- Siempre devuelve el primer valor NULL entre los parámetros de entrada
- Puede aceptar un número ilimitado de parámetros de entrada.
- Devuelve el primer parámetro no nulo; de lo contrario, devuelve un valor nulo.
Answer: C, D. La función COALESCE toma dos parámetros obligatorios y cualquier número de parámetros opcionales. La sintaxis es COALESCE (expr1, expr2, Ö, exprn), donde se devuelve expr1 si no es nulo, de lo contrario expr2 si no es nulo, y así sucesivamente. COALESCE es una forma general de la función NVL, como lo ilustran las siguientes dos ecuaciones: 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?
- 0
- 1
- 2
- 3
Answer: C. La función NVL toma dos parámetros obligatorios. Su sintaxis es NVL (original, ifnull), donde original representa el término que se está probando y ifnull es el resultado devuelto si el término original se evalúa como nulo. Los tipos de datos de los parámetros original e ifnull siempre deben ser compatibles. Deben ser del mismo tipo o debe ser posible convertir implícitamente ifnull al tipo del parámetro original. La función NVL devuelve un valor con el mismo tipo de datos que el parámetro original.
7. What is wrong in the following statement?
NVL (ifnull, original)
- No hay nada malo
- El parámetro original no es obligatorio.
- El parámetro 'ifnull' no es obligatorio
- La declaración correcta es NVL (original, ifnull)
Answer: D. La función NVL evalúa si una columna o expresión de cualquier tipo de datos es nula o no. Si el término es nulo, se devuelve un valor alternativo no nulo; de lo contrario, se devuelve el término inicial.
8. What will be the output of the following query?
SELECT NVL(1234) FROM dual;
- 1234
- 1000
- NULL
- ORA-00909: error de número de argumentos no válido
Answer: D. La función NVL toma dos parámetros obligatorios. Su sintaxis es NVL (original, ifnull), donde original representa el término que se está probando y ifnull es el resultado devuelto si el término original se evalúa como nulo.
9. What will be output of the following query?
SELECT NVL(1234,' ') FROM dual;
- Un espacio en blanco es decir ''
- 1234
- Valor nulo
- ORA-01722: número inválido
Answer: D. Los tipos de datos de los parámetros original e ifnull siempre deben ser compatibles. Deben ser del mismo tipo o debe ser posible convertir implícitamente ifnull al tipo del parámetro original. La función NVL devuelve un valor con el mismo tipo de datos que el parámetro original. El 1234 debe estar entre comillas simples. La conversión implícita del tipo de datos no ocurre en este caso.
10. What will be outcome of the following query?
SELECT NVL(SUBSTR('abc',-4),'SUBSTR didn't work') FROM dual;
- abc
- bc
- c
- SUBSTR no funcionó
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)
SELECT first_name, last_name, commission_pct*salary FROM employees WHERE department_id = 100;
SELECT first_name, last_name, NVL(commission_pct*salary,0) monthly_commission FROM employees WHERE department_id = 100;
SELECT first_name, last_name, NVL(commission_pct,0)*salary monthly_commission FROM employees WHERE department_id = 100;
SELECT first_name, last_name, commission_pct*salary FROM employees;
Answer: B, C.
12. What are the types of Data conversions in Oracle DB?
- Conversiones implícitas
- Conversiones explícitas
- Conversiones externas
- Conversiones físicas
Answer: A, B. TO_CHAR, TO_NUMBER y TO_DATE son las tres funciones de conversión más utilizadas y se analizan en detalle. La función TO_CHAR convierte información numérica y de fecha en caracteres, mientras que TO_NUMBER y TO_DATE convierten datos de caracteres en números y fechas, respectivamente.
13. What happens during an implicit conversion in Oracle DB?
- Oracle DB convierte implícitamente un tipo de datos en el tipo de datos esperado
- El usuario tiene que convertir el tipo de datos al tipo de datos esperado
- Oracle DB no convierte ningún tipo de datos
- La conversión implícita puede ser controlada por el usuario.
Answer: A. Si la base de datos de Oracle convierte implícitamente un valor en un tipo de datos compatible, se conoce como conversión implícita.
14. What happens during an explicit conversion in Oracle DB?
- Oracle DB convierte un tipo de datos en otro y se muestra al usuario explícitamente
- Oracle DB solicita al usuario que convierta un tipo de datos en otro y luego convierte el tipo de datos
- El usuario utiliza funciones de conversión proporcionadas por Oracle DB para convertir tipos de datos
- El tipo de datos nunca se convierte explícitamente en Oracle DB
Answer: C. Cuando el programador tiene que convertir un valor mediante programación usando una de las funciones de conversión, se conoce como conversión explícita.
15. Which of the following conversion methods is recommended for the reliability of SQL statements in Oracle DB?
- Conversiones implícitas y explícitas
- Conversión implícita
- Conversión explícita
- Ninguna de las anteriores
Answer: C. TO_CHAR, TO_NUMBER y TO_DATE son las tres funciones de conversión más utilizadas y se analizan en detalle. La función TO_CHAR convierte información numérica y de fecha en caracteres, mientras que TO_NUMBER y TO_DATE convierten datos de caracteres en números y fechas, respectivamente.
16. Which of the following is a valid implicit conversion performed by Oracle?
- NÚMERO A VARCHAR2
- NÚMERO HASTA LA FECHA
- CHAR HASTA LA FECHA
- FECHA DE 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)
¿Qué método de conversión se aplica a la siguiente consulta?
SELECT first_name, salary
FROM employees
WHERE hire_date > '01-JAN-13';
- No se produce ninguna conversión y esta consulta genera un error de ORA
- Conversión explícita
- Conversión implícita
- Conversión implícita y explícita
Answer: C. La cadena (VARCHAR2 o CHAR) se convierte implícitamente en una FECHA por Oracle dando la salida requerida como seleccionada.
18. Which of the following is supported with respect to expression evaluation is supported by Oracle DB?
- NUMBER TO CHAR
- FECHA DE VARCHAR2
- CHAR hasta la FECHA
- NÚMERO HASTA LA FECHA
Answer: A, B. Los valores DATE y NUMBER se pueden convertir fácilmente a sus equivalentes de caracteres. Las conversiones implícitas de caracteres a fecha son posibles cuando la cadena de caracteres se ajusta a los siguientes patrones de fecha: [D | DD] separador1 [MES | MES] separador2 [R | RR | YY | YYYY].
19. What is mandatory for and implicit conversion of CHAR to NUMBER in Oracle to work?
- Nada en particular es obligatorio para este tipo de conversión.
- Es obligatorio que la cadena de caracteres represente un número válido
- Oracle no admite dicha conversión
- CHAR a NUMBER solo debe convertirse explícitamente
Answer: B. Los datos de caracteres deben representar un número válido para ser considerados para la conversión implícita.
20. Which of the following expressions can be used explicitly for a conversion of a CHAR to a NUMBER?
- TO_CHAR
- Use TO_DATE y luego convierta la fecha en un NÚMERO
- TO_NUMBER
- Tal conversión no es posible
Answer: C. La función TO_NUMBER devuelve un elemento de tipo NUMBER. Las cadenas de caracteres convertidas en números deben tener el formato adecuado para que cualquier componente no numérico se traduzca o elimine con una máscara de formato adecuada.
21. Which of the following expressions can be used explicitly for a conversion of a NUMBER to a CHAR?
- TO_CHAR
- Use TO_DATE y luego convierta la fecha en un NÚMERO
- TO_NUMBER
- Tal conversión no es posible
Answer: A. La función TO_CHAR devuelve un elemento de tipo de datos VARCHAR2. Cuando se aplica a elementos de tipo NÚMERO, hay varias opciones de formato disponibles.
22. Which of the following expressions can be used explicitly for a conversion of a CHAR to a DATE?
- TO_CHAR
- Use TO_DATE y luego convierta la fecha en un NÚMERO
- TO_NUMBER
- TO_DATE
Answer: D. La función TO_DATE devuelve un elemento de tipo FECHA. Las cadenas de caracteres convertidas a fechas pueden contener todos o solo un subconjunto de los elementos de fecha y hora que comprenden una FECHA. Cuando se convierten cadenas con solo un subconjunto de los elementos de fecha y hora, Oracle proporciona valores predeterminados para construir una fecha completa. Los componentes de las cadenas de caracteres se asocian con diferentes elementos de fecha y hora mediante un modelo de formato o una máscara.
23. Which of the following expressions can be used explicitly for a conversion of a DATE to a CHAR?
- TO_CHAR
- TO_DATE
- TO_NUMBER
- Tal conversión no es posible
Answer: A. La función TO_CHAR devuelve un elemento de tipo de datos VARCHAR2. Cuando se aplica a elementos de tipo NÚMERO, hay varias opciones de formato disponibles.
24. Which of the following are the functions for explicit conversion provided by Oracle to convert one data type to the other?
- TO_CHAR
- TO_DATE
- TO_NUMBER
- Todas las anteriores
Answer: D. TO_CHAR, TO_NUMBER y TO_DATE son las tres funciones de conversión más utilizadas y se analizan en detalle. La función TO_CHAR convierte información numérica y de fecha en caracteres, mientras que TO_NUMBER y TO_DATE convierten datos de caracteres en números y fechas, respectivamente.
25. Interpret the working of the below function.
TO_CHAR(number/date, [format], [nlsparameters])
- Convierte un VARCHAR2 en un CHAR
- Convierte un número / fecha en una cadena VARCHAR2 con el modelo de formato [formato]
- Convierte un VARCHAR2 en un NÚMERO o una FECHA
- [NLSPARAMETERS] es obligatorio en la declaración
Answer: B. La función TO_CHAR devuelve un elemento de tipo de datos VARCHAR2. Cuando se aplica a elementos de tipo NÚMERO, hay varias opciones de formato disponibles.
26. What does the [NLSPARAMETERS] clause in the following statement specify?
TO_CHAR(number/date, [format], [nlsparameters])
- Carácter decimal
- Separador de grupos
- Símbolo de moneda
- Todas las anteriores
Answer: D.
27. What value will the TO_CHAR (number/date, [format], [nlsparameters]) use if the [nlsparameters] parameter is omitted?
- Lanza un error ORA
- El parámetro [nlsparameters] es obligatorio y no se puede omitir.
- Utilizará los valores de los parámetros predeterminados para la sesión.
- Utilizará los valores de parámetros predeterminados establecidos durante el diseño de la base de datos.
Answer: C. De forma predeterminada, la función TO_CHAR considera la configuración de NLS de la sesión activa actual.
28. What is true about the following statement?
TO_CHAR(number/date, [format], [nlsparameters])
- El parámetro nlsparameters especifica el idioma en el que se devuelven los nombres de mes y día.
- El parámetro nlsparameters se omite en la ejecución de la declaración anterior.
- El parámetro nlsparameters devolverá un NULL ya sea especificado o no
- El parámetro nlsparameters devolverá el idioma predeterminado de la base de datos en cada ejecución
Answer: A.
29. What is true regarding the following statement in Oracle DB?
TO_NUMBER(char, [format],[nlsparameters])
- Convierte cualquier cadena en un número en el formato especificado en [formato]
- Convierte solo un NÚMERO al formato deseado como se menciona en [formato]
- Convierte una cadena con dígitos en un número en el formato especificado en [formato]
- El resultado de esta función es siempre un carácter
Answer: C. La función TO_NUMBER devuelve un elemento de tipo NUMBER. Las cadenas de caracteres convertidas en números deben tener el formato adecuado para que cualquier componente no numérico se traduzca o elimine con una máscara de formato adecuada.
30. What is true regarding the following statement in Oracle DB?
TO_DATE(char, [format],[nlsparameters])
- Convierte cualquier cadena a una FECHA en el formato especificado en [formato]
- Convierte solo una FECHA en otra FECHA en el formato deseado como se menciona en [formato]
- Convierte una cadena con FECHA en un número en el formato especificado en [formato]
- Convierte una cadena con FECHA en FECHA en el formato especificado en [formato]
Answer: C. La función TO_DATE devuelve un elemento de tipo FECHA. Las cadenas de caracteres convertidas a fechas pueden contener todos o solo un subconjunto de los elementos de fecha y hora que comprenden una FECHA.
31. What will be the result if the [format] parameter in the following statement is omitted?
TO_DATE(char, [format],[nlsparameters])
- Devolverá un valor de FECHA con el formato DD-MON-YY
- Devolverá un valor de FECHA con el formato DD-MON-RR
- Devolverá un valor de carácter
- Devolverá un valor NUMBER
Answer: A.
32. Which of the following is true about the following statement in Oracle DB?
TO_CHAR(date, 'frmt')
- El fmt se puede escribir tanto entre comillas dobles como entre comillas simples.
- El caso del fmt no importa en esta función
- Fmt puede incluir cualquier carácter o NÚMERO
- El fmt debe ir entre comillas simples y debe tener un formato de fecha válido.
Answer: D.
33. What will the following statement on execution yield?
SELECT TO_CHAR ('01-JAN-13' 'DD-MON-YY') FROM dual;
- 01-JAN-13
- 01-01-2013
- Un error de ORA
- 1-JAN-13
Answer: C. Los parámetros '01 -JAN-13 'y el modelo de formato deben estar separados por un ",".
34. What is true about the [fmt] parameter in the following statement?
TO_DATE ([date as string],[format])
- El fmt se puede escribir tanto entre comillas dobles como entre comillas simples.
- El caso del fmt no importa en esta función
- El parámetro [fmt] tiene un elemento 'fm' que elimina los espacios y suprime los ceros iniciales.
- Fmt puede incluir cualquier carácter o NÚMERO
Answer: C.
35. What is the abbreviation for the FM modifier in Oracle DB?
- Primera jugada
- Modo de filtro
- Modo de llenado
- Primer modo
Answer: C. El modelo de formato 'fm' significa Modo de relleno.
36. What is the abbreviation for the FX modifier in Oracle DB?
- Primera expresión
- Expresión de relleno
- Primer extra
- Formato exacto
Answer: D. El modelo de formato 'fm' significa Formato Exacto.
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;
- 5
- 6
- 7
- 9
Answer: D. La palabra más larga para el mes es 'septiembre' y, por lo tanto, Oracle se adapta a 9 lugares para la visualización del parámetro Mes.
38. Which of the following is true about the FM modifier in Oracle DB?
- Este modificador suprime el relleno en blanco en los siguientes elementos de carácter, como MES.
- Este modificador suprime los ceros iniciales para el número subsiguiente de elementos, como MI
- Este modificador no tiene ningún efecto en el formato de fecha.
- Este modificador es obligatorio para todos los formatos de fecha utilizados con la función TO_CHAR
Answer: A, B.
39. What happens when the FM modifier is not used in the DATE format model in Oracle DB?
- El resultado del elemento de carácter se rellena con espacios en blanco hasta una longitud variable
- El resultado del elemento de carácter se rellena a la derecha con espacios en blanco hasta una longitud fija
- Los ceros iniciales no se devuelven en el resultado del elemento de carácter
- La longitud del valor de retorno es fija si se usa el modificador 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?
- Right
- Left
- Centre
- Ninguna de las anteriores
Answer: B. El modificador FM suprime los espacios en blanco agregados a la izquierda del número.
41. What will be the outcome of the following query?
SELECT TO_CHAR (TO_DATE('01-JAN-13'), 'fmDD Month YYYY') FROM dual;
- 1 de enero de 2013
- 1 de enero de 2013
- 1 de enero de 2013
- 1 de enero 13
Answer: B. TO_CHAR formatea la fecha de entrada según el modelo de formato dado.
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;
- 0
- 1
- 2
- 3
Answer: A. El modificador FM elimina todos los espacios rellenados del formato de fecha.
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;
- Devolverá un error ORA debido al uso de comillas dobles en el formato de fecha
- 1 de enero de 2013
- Primero de ENERO 2013 12:00:00 AM
- Primero de enero de 2013 12:00:00 AM
Answer: D. TO_CHAR formatea la fecha de entrada '01 -JAN-13 'según el formato dado.
44. Which of the following specifies the exact match for the character argument and the date format model of a TO_DATE function?
- TO_DATE
- TO_CHAR
- FM
- FX
Answer: D.
45. What is true about the FX modifier in the Oracle DB?
- Es sensible a mayúsculas y minúsculas
- Ignora los espacios en el argumento de carácter cuando coincide con el modelo de formato de fecha mencionado
- Los signos de puntuación y el texto citado en el argumento del carácter no coinciden necesariamente con el modelo de formato.
- Ninguna de las anteriores
Answer: D.
46. What will be the outcome of the following query?
SELECT TO_DATE ('January 21, 2013' , 'fxMonth DD, YYYY') FROM dual;
- Se ejecutará con éxito
- Dará el resultado el 21 de enero de 2013
- Crea un error ORA
- Dará el resultado 21 DE ENERO DE 2013
Answer: C. El argumento del carácter debe coincidir exactamente con el modelo de formato si se utiliza FX. Aquí, los espacios adicionales después de enero no coinciden.
47. What is true about the FX modifier in Oracle DB?
- Se puede utilizar con TO_CHAR
- Se puede usar con TO_CHAR y TO_DATE
- Se puede usar solo con TO_DATE
- Ninguna de las anteriores
Answer: C. El modificador de formato FX solo se puede utilizar con la función 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 de enero
- 1st
- 1 ST
- 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 de enero
- 1st
- 1ST
- 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;
- Tuesday
- TUESDAY
- Reunión del MARTES
- Reunión del martes
Answer: D.
51. What will be the outcome of the following query?
SELECT TO_DATE('01 / JAN / 13','DD-MON-YY') FROM dual;
- Error de ORA
- 01-JAN-2013
- 01-JANUARY-13
- 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;
- Error de ORA
- 01-JAN-2013
- 01-JANUARY-13
- 01-JAN-13
Answer: A. Utilice un solo delimitador entre las fechas.
53. What will be the outcome of the following query?
SELECT TO_DATE('01/JAN/13','fxDD-MON-YY') FROM dual;
- 01-JAN-2013
- Error de ORA
- 01-JAN-13
- 01-JANUARY-13
Answer: B. Con el modificador de formato exacto, el literal de entrada debe coincidir con la cadena de formato.
54. What will be the outcome of the following query?
SELECT TO_DATE('01-JAN-13','fxDD-MON-YY') FROM dual;
- 01-JAN-2013
- Error de ORA
- 01-JAN-13
- 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;
- 11-JAN-13
- 11-01-13
- 11-JAN-2013
- Error de 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';
- Error de ORA
- 01-JAN-2013
- 1-JAN-13
- 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;
- 01-JAN-13
- 01-01-2013
- 01-January-13
- 01-enero -13
Answer: D. El modificador de mes se rellena hasta en 9 lugares con espacios.
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')
- DÓNDE_FECHA (fecha_contratación, 'DD-MON-AA') <'01 -JAN-1990 '
- DÓNDE HASTA FECHA (fecha de contratación, 'DD-MON-AAAA') <'01 -JAN-1990 '
- DÓNDE HASTA FECHA (fecha de contratación, 'DD-MON-AA') <'01 -JAN-90 '
- DÓNDE_FECHA_ (fecha_contratación, 'DD-MON-RR') <'01 -JAN-1990 '
Answer: D. El uso del formato RR considerará la parte del año de la fecha entre 1950 y 1999.
59. Which of the following is an example of a nested function?
SELECT lower(last_name) FROM employees;
SELECT upper (last_name) FROM employees;
SELECT concat (first_name, last_name) FROM employees;
SELECT upper (concat(SUBSTR(first_name,1,6),'_UK')) FROM employees;
Answer: D. Más de una función en una función se conoce como anidamiento de funciones.
60. What is true about the COALESCE function in Oracle DB?
- Solo puede tomar 2 argumentos
- Todos los argumentos de la función COALESCE pueden ser de diferentes tipos de datos
- Todos los argumentos de la función COALESCE deben ser del mismo tipo de datos
- Ninguna de las anteriores
Answer: C. La función COALESCE toma dos parámetros obligatorios y cualquier número de parámetros opcionales. La sintaxis es COALESCE (expr1, expr2, Ö, exprn), donde se devuelve expr1 si no es nulo, de lo contrario expr2 si no es nulo, y así sucesivamente.
61. Which of the following functions is used for conditional expressions?
- TO_CHAR
- COALESCE
- NVL
- CASE
Answer: D. La expresión CASE facilita la lógica condicional if-then-else. Hay dos variantes de la expresión CASE. La expresión CASE simple enumera el elemento de búsqueda condicional una vez, y cada expresión de comparación prueba la igualdad con el elemento de búsqueda. La expresión CASE buscada enumera una condición separada para cada expresión de comparación.
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;
- 01-jan-2013
- 01-jan-13
- tue-jan-13
- tue-jan-2013
Answer: D. El modelo de formato 'dy' deletrea las primeras tres letras del día a partir de la fecha de entrada. "DY" dará "TUE" y no "tue" como en la consulta anterior.
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-jan-2013
- 01-jan-13
- MARTES -ene-13
- TUESDAY-jan-2013
Answer: D. El modelo de formato fmDAY (para todas las letras mayúsculas) o fmday (para todas las letras minúsculas) deletreará el día de la fecha de entrada sin espacios iniciales o finales.
64. What will be the outcome of the following query?
SELECT TO_CHAR(TO_DATE('19-JUN-13'),'qth') FROM dual;
- 1st
- 2nd
- 3rd
- 4th
Answer: B. El modelo de formato 'q' da el trimestre en el que cae la fecha dada. En la consulta dada, ABR-JUN es el segundo trimestre.
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?
SELECT first_name, last_name, department_id FROM employees WHERE TO_DATE(hire_date,'w') >2;
SELECT first_name, last_name, department_id FROM employees WHERE TO_DATE(hire_date,'w') between 1 and 2;
SELECT first_name, last_name, department_id FROM employees WHERE TO_CHAR(hire_date,'w') <3;
SELECT first_name, last_name, department_id FROM employees WHERE TO_CHAR(sysdate,'ww') =2;
Answer: D. El modelo de formato 'ww' da la semana del año.
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?
SELECT count(employee_id ) FROM employees WHERE TO_CHAR(hire_date, 'q') > 1;
SELECT count(employee_id ) FROM employees Where TO_CHAR(hire_date, 'q') = 3;
SELECT employee_id FROM employees Where TO_CHAR(hire_date, 'q') = 3;
SELECT count(employee_id ) FROM employees Where TO_CHAR(hire_date, 'q') between 0 and 3;
Answer: B. El modelo de formato 'q' da el trimestre de un año.
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?
SELECT TO_CHAR (hire_date, 'fmDay,"the "ddth "of " Month, Yysp.') FROM employees;
SELECT TO_CHAR (hire_date, 'Day,"the "ddth "of " Mon, Yyyy.') FROM employees;
SELECT TO_CHAR (hire_date, 'fmDAY,"the "ddth "of " Month, Ysp.') FROM employees;
SELECT TO_CHAR (hire_date, 'fmDay,"the "ddth "of " MONTH, Rsp.') FROM employees;
Answer: A. El identificador 'sp' deletrea el año en un idioma inglés simple.
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?
- TO_DATE('2011','YYYY')
- TO_CHAR (TO_DATE ('2011', 'YYYY'), 'fmMM / DD / YYYY')
- TO_CHAR('2011','DD-MON-YYYY')
- TO_DATE ('01-01-2011 ',' DD-MM-AAAA ')
Answer: B.
69. What will be the outcome of the following query?
SELECT TO_NUMBER ('$3000') FROM dual;
- 3000
- $3000
- NULL
- Error de ORA
Answer: D. La consulta arroja el error "ORA-01722: número inválido" porque la cadena dada no se puede reconocer en números.
70. What will be the outcome of the following query?
SELECT TO_NUMBER('$3,000.67','$999,999.99') FROM dual;
- $3000.67
- 3000
- 3000.67
- Error de ORA ya que la cadena de entrada tiene menos caracteres que el modelo de formato mencionado.
Answer: C. El modelo de formato apropiado ayuda al TO_NUMBER a convertir una cadena dada en números.
71. What will be the outcome of the following query?
SELECT TO_NUMBER('$3,000,000.67','$999,999.99') FROM dual;
- $3,000,000.67
- 3000,000.67
- 3000.67
- Error de ORA ya que el modelo de formato tiene menos caracteres que la cadena de entrada. Debería ser el mismo.
Answer: D.
72. What will the following query yield?
SELECT TO_NUMBER('456.23','999.99') FROM dual;
- Error de ORA
- 456.23
- 456
- Ninguna de las anteriores
Answer: B.
73. What is true about the nested functions?
- El anidamiento implica el uso de la salida de una función como entrada a otra.
- El anidamiento se puede aplicar hasta en 3 niveles de anidamiento.
- El anidamiento se aplica a funciones de varias filas a cualquier nivel de profundidad
- Ninguna de las anteriores
Answer: A. La salida de la ejecución de una función se utiliza como entrada para su función anterior.
74. What will be the result of the following query?
SELECT NULLIF(1,2-1) FROM dual;
- 0
- 1
- NULL
- Ninguna de las anteriores
Answer: C. La función NULLIF prueba la igualdad de dos términos. Si son iguales, la función devuelve un valor nulo, de lo contrario, devuelve el primero de los dos términos probados. Aquí 1 y la expresión "2-1" se consideran iguales por Oracle y, por lo tanto, se devuelve NULL.
75. What will be the outcome of the following query?
SELECT NULLIF('01-JAN-2013','01-JAN-13') FROM dual;
- 1-JAN-13
- 01-JAN-2013
- NULL
- Error de ORA
Answer: B. Dado que la duración de ambas fechas es diferente, se devuelve el primer parámetro.
76. What is the ratio of mandatory parameters to optional parameters in the COALESCE function in Oracle DB?
- 0:1
- 1:2
- 2: cualquier número
- Ninguna de las anteriores
Answer: C. La función COALESCE toma dos parámetros obligatorios y cualquier número de parámetros opcionales. OALESCE es una forma general de la función NVL, como lo ilustran las dos ecuaciones siguientes: COALESCE (expr1, expr2) = NVL (expr1, expr2), COALESCE (expr1, expr2, expr3) = NVL (expr1, NVL (expr2, expr3) ).
77. Which of the following equations are true?
- COALESCE (expr1, expr2) = NVL (expr1, expr2)
- COALESCE (expr1, expr2) = NVL2 (expr1, expr2, expr3)
- COALESCE (expr1, expr2, expr3) = NVL (expr1, NVL (expr2, expr3))
- Todas las anteriores
Answer: A, C.
78. Which of the following is the correct syntax of NVL2?
- NVL(original,ifnotnull)
- NVL2(original,ifnull,ifnotnull)
- NVL(original,NULL)
- NVL (original, ifnull) y NVL2 (original, ifnotnull, ifnull)
Answer: D.
79. Which of the following functions is an ANSI standard keyword inherited in Oracle?
- CASE
- DECODE
- Tanto a como B
- Ninguna de las anteriores
Answer: A. CASE cumple con ANSI SQL y no es específico de Oracle.
80. What is true about the DECODE statement in Oracle DB?
DECODE(expr1,comp1,iftrue1,comp2,[iftrue2])
- Comp2 no es opcional
- Si expr1 es igual a comp1, se devuelve comp2
- Si expr1 es igual a comp1, se devuelve iftrue1
- Ninguna de las anteriores
Answer: C. La función DECODE implementa la lógica condicional if-then-else probando sus dos primeros términos para la igualdad y devuelve el tercero si son iguales y, opcionalmente, devuelve otro término si no lo son. La función DECODIFICAR toma al menos tres parámetros obligatorios, pero puede tomar muchos más.
81. What is true about the parameters in the DECODE function?
- Todos los parámetros deben ser VARCHAR2
- Ninguna expresión puede ser un parámetro para la función DECODIFICAR
- Todos los parámetros deben ser NUMBER
- El tipo de datos devuelto es el mismo que el del primer elemento de comparación coincidente.
Answer: D. La función DECODE implementa la lógica condicional if-then-else probando sus dos primeros términos para la igualdad y devuelve el tercero si son iguales y, opcionalmente, devuelve otro término si no lo son.
82. What will be the outcome of the following query?
SELECT DECODE (null,null,'expr3') FROM dual;
- NULL
- 0
- Expr3
- Error de ORA
Answer: C. DECODE considera que dos valores NULL son equivalentes. Una de las anomalías de NULL en 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;
- elephant
- rat
- koala
- Y sigue
Answer: D. La función DECODIFICAR toma al menos tres parámetros obligatorios, pero puede tomar muchos más.
84. What is the number of minimum mandatory parameters for the CASE expression in Oracle DB?
- 0
- 1
- 2
- 3
Answer: D. La expresión CASE facilita la lógica condicional if-then-else. Hay dos variantes de la expresión CASE. La expresión CASE simple enumera el elemento de búsqueda condicional una vez, y cada expresión de comparación prueba la igualdad con el elemento de búsqueda. La expresión CASE buscada enumera una condición separada para cada expresión de comparación. Toma al menos 3 parámetros obligatorios pero también puede tomar más.
85. Which of the following keyword combinations is used to enclose a CASE statement in Oracle DB?
- CASEÖEND SI;
- IFÖEND IF;
- CASEÖ;
- 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?
- 0
- NULL
- O 0 o NULO
- Ninguna de las anteriores
Answer: B.
87. Which of the following options is true if more than one WHEN..THEN levels exist in a CASE statement?
- El CASO busca o compara solo el primer nivel y existe sin verificar otros niveles de WHENÖTHEN.
- La instrucción CASE buscará en todos los niveles de WHENÖTHEN hasta que encuentre una coincidencia.
- Tanto a como B
- Ninguna de las anteriores
Answer: B.
88. What data types can be the search, comparison and result parameters in the CASE statement?
- VARCHAR2
- DATE
- NUMBER
- Valores de columna, literales y expresiones
Answer: D.
89. The CASE statement cannot be used in which of the following parts of an Oracle SQL query?
- SELECT
- Ninguna de estas opciones
- WHERE
- PEDIR POR
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)
¿Cuál será el resultado de la siguiente consulta en 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;
- Se creará un error ORA ya que no se pueden escribir más de una declaración WHENÖTHEN en la declaración CASE.
- Mostrará los ID de departamento como 100,101,102
- Solo mostrará 'Cuentas' siempre que aparezca el ID de departamento 100 e ignorará los comandos restantes.
- Ninguna de las anteriores
Answer: D. La expresión CASE facilita la lógica condicional if-then-else. Hay dos variantes de la expresión CASE. La expresión CASE simple enumera el elemento de búsqueda condicional una vez, y cada expresión de comparación prueba la igualdad con el elemento de búsqueda. La expresión CASE buscada enumera una condición separada para cada expresión de comparación.
91. What is the maximum number of WHENÖTHEN levels a CASE statement in Oracle DB can have?
- Unlimited
- 1000
- 216
- 255
Answer: D.
92. What will be the outcome of the following query?
SELECT NVL2(
NULLIF ('BMW','AUDI'),
'HYUNDAI',
'FERRARI'
)
FROM dual;
- BMW
- FERRARI
- NULL
- HYUNDAI
Answer: D. La función NVL2 proporciona una mejora a NVL pero tiene un propósito muy similar. Evalúa si una columna o expresión de cualquier tipo de datos es nula o no. Si el primer término no es nulo, se devuelve el segundo parámetro, de lo contrario se devuelve el tercer parámetro.
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 de enero de 2013
- 1 de enero de 2013
- 01 de enero de 2013
- 1 de enero de 2013
Answer: D. El modelo de formato "ésimo" da el día de la fecha como "st" o "th".
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;
- Primero de enero de dos mil trece
- Primero ENE dos mil trece
- Uno de enero de dos mil trece
- Ninguna de las anteriores
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;
- Primero de enero de dos mil trece
- Uno de enero de dos mil trece
- Error de ORA
- 01-ENE-2013 cero
Answer: D. Se puede deletrear el componente de marca de tiempo utilizando el modificador de formato 'SpTh'.
96. Which of these functions do the work similar to if-then-else logic in SQL statements?
- TO_CHAR
- TO_NUMBER
- Tanto a como B
- CASE
Answer: D. La expresión CASE facilita la lógica condicional if-then-else. Hay dos variantes de la expresión CASE. La expresión CASE simple enumera el elemento de búsqueda condicional una vez, y cada expresión de comparación prueba la igualdad con el elemento de búsqueda. La expresión CASE buscada enumera una condición separada para cada expresión de comparación.
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)
¿Cuál será el resultado de la siguiente consulta SQL?
SELECT DECODE (salary,10000) FROM employees;
- 10000
- NULL
- 0
- Error de ORA
Answer: B. La función DECODE implementa la lógica condicional if-then-else probando sus dos primeros términos para la igualdad y devuelve el tercero si son iguales y, opcionalmente, devuelve otro término si no lo son. La función DECODIFICAR toma al menos tres parámetros obligatorios, pero puede tomar muchos más. Si se omite el valor predeterminado en la función DECODIFICAR, se devuelve 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?
SELECT TO_CHAR(sysdate, 'DD-MON-YY HH24:MI:SS.FF') FROM dual;
SELECT TO_CHAR(sysdate, 'DD-MON-YY HH24:MI:SS') FROM dual;
SELECT TO_CHAR(sysdate, 'DD-MON-YY HH24:MI:SS.FF3') FROM dual;
SELECT TO_CHAR(sysdate, 'DD-MON-YY') FROM dual;
Answer: C. La extensión FF [1..9] al formato HH: MI: SS produce fracciones de segundo hasta 1..9 dígitos en fracciones de segundo.
99. Which of the following punctuation marks can be used with Dates and Times in Oracle DB?
- #
- @
- ,
- :
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)
Debe encontrar el día del año en que se contrató a la empleada Jaimie Patrick en la empresa 'ABC'. ¿Cuál de las siguientes consultas dará el resultado requerido?
SELECT TO_CHAR(hire_date, 'DDD') FROM employees WHERE last_name = 'Patrick' AND first_name = 'John';
SELECT TO_CHAR(hire_date, 'YYYY') FROM employees WHERE last_name = 'Patrick' AND first_name = 'John';
SELECT TO_CHAR(hire_date, 'DD-MON-YYYY') FROM employees WHERE last_name = 'Patrick' AND first_name = 'John';
SELECT TO_CHAR(hire_date, 'DD-MON-RR') FROM employees WHERE last_name = 'Patrick' AND first_name = 'John';
Answer: A. El modelo de formato 'DDD' devuelve el día del año en el que cae la fecha indicada.
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?
- TO_CHAR(sysdate,'HH24:MI:SS')
- TO_CHAR(sysdate,'HH24:MI:SS.FF')
- TO_CHAR(sysdate,'HH24:MI:SSSS')
- TO_CHAR(sysdate,'HH24:MI:SS.FF3')
Answer: C. el modelo de formato 'SSSS' da los segundos después de la medianoche.