Preguntas sobre obtener datos de varias tablas

1.Which of the following is not related to a Relational Database?

  1. Selection
  2. Projection
  3. Joining
  4. Ninguna de las anteriores

Answer: D. Las opciones A, B y C son las principales capacidades de Oracle Relational Database.

2.Which of the following methods is used for writing a query with columns from multiple tables?

  1. SELECT
  2. AGRUPAR POR
  3. PEDIR POR
  4. JOINS

Answer: D. Las uniones se utilizan para conectar varias tablas y datos de columna del proyecto de varias tablas en Oracle.

3.Which of the following is one of the most common methods to join multiple tables?

  1. Hash Join
  2. Equijoin
  3. Auto unión
  4. Unión cruzada

Answer: B. Equijoin es uno de los tipos de uniones que es la técnica más común y simple para unir más de una tabla. Los equijoins también se denominan uniones simples o uniones internas, que involucran la clave primaria y la clave externa.

4.Which of following will be used to join rows with other tables if the column values fall in a range defined by inequality operators?

  1. Equijoin
  2. Unión simple
  3. Non-equijoin
  4. Ninguna de las anteriores

Answer: C. Los equijoins usan operadores de igualdad para unir filas, los no equijoins usan operadores de desigualdad.

5.Which of the following statements is true about Oracle joins?

  1. Los valores NULL se incluyen en el conjunto de resultados
  2. Solo se recuperan las filas que tienen condiciones coincidentes
  3. Se obtienen todas las filas que están presentes en cualquiera de las tablas
  4. Ninguna de las anteriores

Answer: B. Los valores NULL y las diferentes entradas en columnas de combinación comunes se excluyen cuando se utilizan combinaciones.

6.Which of the following can be used to join the rows of a table with other rows of the same table?

  1. Equijoin
  2. Non-equijoin
  3. Unión externa
  4. Self-join

Answer: D. La asociación se basa en columnas con relaciones lógicas y generalmente jerárquicas entre sí.

7.What is true about a cartesian join of two tables in Oracle DB?

  1. Debe evitarse ya que es costoso y no está optimizado.
  2. Se forma cuando cada fila de una tabla se une con todas las filas de la segunda tabla.
  3. Tanto a como B
  4. Ninguna de las anteriores

Answer: B. La unión cartesiana es a menudo el resultado de condiciones de unión inadecuadas o faltantes. Es simplemente el producto cruzado de dos tablas.

8.Which of the following is one of the basic types of joins in Oracle DB ?

  1. Unión externa
  2. Self-join
  3. Equi-join
  4. Todas las anteriores

Answer: C. Equi-join y non-equijoin son los dos tipos básicos de uniones en Oracle DB.

9.What is the main condition for using joins between a source table and a target table in Oracle DB for getting a non-cartesian product result?

  1. No hay condición
  2. Al menos una de las columnas en ambas tablas debe ser común.
  3. Los nombres de las columnas en ambas tablas de unión deben ser los mismos para usar combinaciones
  4. Ninguna de las anteriores

Answer: B. Las tablas deben estar conectadas a través de una columna común que relacione dos entidades. La tabla unida en una columna común produce un producto no cartesiano.

10. Which of the following can be used to fetch rows from multiple tables in a single SQL query?

  1. SELECT
  2. WHERE
  3. FROM
  4. Equi-joins

Answer: D. Los equijoins también se denominan uniones simples o uniones internas. Equijoin implica la clave principal y la clave externa.

11.What is true about the source table and the target table in terms of Oracle Joins?

  1. Deben tener al menos una columna del mismo nombre
  2. Todas las columnas deben tener el mismo nombre y el mismo tipo de datos para unir las dos tablas.
  3. Las tablas de origen y destino no se pueden intercambiar y son específicas de la posición
  4. Ninguna de las anteriores

Answer: D. Las tablas de origen y de destino se pueden intercambiar y no están fijas en sus posiciones. Dependiendo del tipo de combinación utilizada en la consulta, el resultado puede diferir o permanecer igual.

12.What is true about Natural joins in Oracle DB?

  1. Los nombres de columna de las tablas de origen y destino deben ser idénticos
  2. Si los nombres de columna de las tablas de origen y destino no son los mismos, Oracle implícitamente hace lo necesario
  3. NATURAL JOINS, USING y ON son las palabras clave asociadas con Natural Joins
  4. Todas las anteriores

Answer: C. La palabra clave NATURAL JOIN indica a Oracle que identifique columnas con nombres idénticos entre las tablas de origen y destino. Las combinaciones naturales usan todas las columnas con nombres y tipos de datos coincidentes para unir las tablas. La cláusula USING se puede usar para especificar solo aquellas columnas que deben usarse para una combinación equitativa.

13.Assume the tables EMPLOYEES and DEPARTMENT have to be joined using NATURAL JOIN. What is the difference between the following two queries which follow? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SELECT department_id 
FROM employees NATURAL JOIN department
WHERE first_name = 'John'
AND last_name = 'Bacon';
SELECT department_id 
FROM department NATURAL JOIN employees
WHERE first_name = 'John'
AND last_name = 'Bacon';
  1. No hay diferencia
  2. El resultado es diferente en ambos casos
  3. Ambas consultas darán un error ORA en la ejecución.
  4. Ninguna de las anteriores

Answer: B. Las tablas de origen y destino se pueden intercambiar mientras se usa NATURAL JOIN, lo que proporciona conjuntos de resultados relacionalmente diferentes.

14.Which of the following options is true regarding the NATURAL JOIN in Oracle DB?

  1. Al usar NATURAL JOIN, es obligatorio mencionar los nombres de todas las columnas de ambas tablas
  2. NATURAL JOIN se puede usar solo si los nombres de todas las columnas de ambas tablas son idénticos
  3. La combinación en NATURAL JOIN ocurre solo cuando el usuario especifica las columnas de las tablas de origen y destino.
  4. No es necesario mencionar las columnas al usar NATURAL JOINS.

Answer: D. Hay una unión implícita de las columnas de la fuente y las tablas de destino cuando se usa un NATURAL JOIN. UN NATURAL JOIN es una operación JOIN que crea una cláusula de combinación implícita para usted en función de las columnas comunes en las dos tablas que se unen. Las columnas comunes son columnas que tienen el mismo nombre en ambas tablas.

15. What is the difference between a NATURAL JOIN and a join with JOIN..ON?

  1. No hay diferencia entre ambos
  2. JOIN..ON une las tablas de origen y destino en columnas específicas con el mismo nombre
  3. NATURAL JOIN une implícitamente todas las columnas coincidentes de las tablas de origen y destino
  4. Ninguna de las anteriores

Answer: B, C. La condición de combinación para la combinación natural es básicamente una combinación de todas las columnas con el mismo nombre. Utilice la cláusula ON para especificar condiciones arbitrarias o especificar columnas para unir. La condición de combinación está separada de otras condiciones de búsqueda. La cláusula ON hace que el código sea fácil de entender.

16.What is true about the JOIN..ON clause in Oracle DB?

  1. No depende de que las columnas de las tablas de origen y destino tengan nombres idénticos
  2. Solo aquellas columnas de las tablas de origen y destino que tienen nombres idénticos se pueden usar con esta cláusula
  3. Es un formato de NATURAL JOIN
  4. Todas las anteriores

Answer: A, C. La condición de combinación para la combinación natural es básicamente una combinación de todas las columnas con el mismo nombre. Utilice la cláusula ON para especificar condiciones arbitrarias o especificar columnas para unir. La condición de unión está separada de otras condiciones de búsqueda. La cláusula ON hace que el código sea fácil de entender.

17. The database designer has named the key (unique) columns from two tables differently.While joining these tables, which among the following will be the best practice?

  1. JOIN..ON
  2. Cláusulas NATURAL JOIN o JOIN ... ON
  3. Tanto a como B
  4. Ninguna de las anteriores

Answer: A. El uso de NATURAL JOINS en este caso puede producir resultados inesperados, ya que existe una búsqueda implícita de columnas con nombres idénticos que en este caso no está presente.

18.What of the following can be used to fetch non-matching rows along with the matching rows between a source and a target table in Oracle DB?

  1. EQUI-JOIN
  2. SELF-JOIN
  3. UNIÓN NATURAL
  4. OUTER-JOIN

Answer: D. Se crea una combinación externa cuando los registros deben incluirse en los resultados sin tener los registros correspondientes en las tablas de combinación. Estos registros se comparan con los registros NULL para que se incluyan en la salida.

19. What are Cartesian Joins also known as in Oracle DB?

  1. Equi-join
  2. Anti-join
  3. Cross-Join
  4. Ninguna de las anteriores

Answer: C. Una combinación cartesiana entre dos tablas devuelve todas las combinaciones posibles de filas de las tablas. Se puede producir una combinación cartesiana si no se incluye una operación de combinación en la consulta o si se usa CROSS JOIN.

20.What will be the result of a NATURAL JOIN between two tables EMPLOYEES and DEPARTMENT as given in the query below? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SELECT * FROM employees NATURAL JOIN department;
  1. La columna común DEPARTMENT_ID con nombre idéntico en ambas tablas aparecerá dos veces en el conjunto de resultados
  2. Todas las columnas que tengan nombres idénticos unidas con NATURAL JOIN, aparecerán dos veces en el conjunto de resultados.
  3. El conjunto de resultados tendrá solo una columna para cada par de columnas con el mismo nombre de ambas tablas
  4. Ninguna de las anteriores

Answer: C. Las palabras clave NATURAL JOIN no requieren una condición para establecer la relación entre dos tablas. Sin embargo, debe existir una columna común. Los calificadores de columna no se pueden utilizar con las palabras clave NATURAL JOIN.

21.What is the difference between a NATURAL JOIN and an EQUI-JOIN in Oracle DB?

  1. No hay diferencia
  2. Son iguales con respecto al conjunto de resultados que se obtiene de ambos
  3. Tanto a como B
  4. Ninguna de las anteriores

Answer: D. NATURAL JOIN une todas las columnas con nombres idénticos, mientras que EQUI-JOIN requiere que las columnas se mencionen explícitamente en la consulta SQL.

22.What is an INNER JOIN in Oracle DB?

  1. La combinación que proporciona los registros coincidentes entre dos tablas se llama INNER JOIN
  2. Una combinación interna puede usar operadores como <,>, <>
  3. Tanto a como B
  4. Ninguna de las anteriores

Answer: C. Una combinación puede ser una combinación interna, en la que los únicos registros devueltos tienen un registro coincidente en todas las tablas, o una combinación externa, en la que se pueden devolver registros independientemente de si hay un registro coincidente en la combinación.

23.What is the difference between a INNER JOIN and an EQUI-JOIN in Oracle DB?

  1. Son iguales en términos de sintaxis y conjuntos de resultados obtenidos.
  2. Un INNER JOIN es un subconjunto de un EQUI-JOIN
  3. Un INNER JOIN puede usar operadores como <,>, <> junto con "=" mientras que EQUI-JOIN solo usa el operador "="
  4. Todas las anteriores

Answer: C. EQUI-JOIN es un tipo de INNER JOIN que contiene el operador "=" en una condición de unión, mientras que INNER JOIN puede contener tanto operadores de igualdad como de no igualdad

24.What is true about NATURAL JOINS in terms of ANSI SQL: 1999 syntaxes in Oracle DB?

  1. Se utiliza un operador de igualdad (=)
  2. Obtienen resultados diferentes en comparación con la sintaxis tradicional
  3. La sintaxis ANSI SQL utiliza palabras como NATURAL JOIN en las consultas SQL
  4. Ninguna de las anteriores.

Answer: C. La sintaxis ANSI SQL es diferente de la forma tradicional de usar (=) en las formas tradicionales. Hay palabras clave como NATURAL JOIN, etc. en la sintaxis ANSI SQL para distinguir las uniones utilizadas.

25.What of the following is true with respect to the query given below? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SELECT first_name, salary
FROM employees e, departments d
WHERE e.department_id  (+) = d.department_id ;
  1. Hay una combinación externa entre el department_id de ambas tablas que es equivalente a una combinación externa derecha en ANSI SQL
  2. Hay una combinación externa entre el department_id de ambas tablas que es equivalente a una combinación externa izquierda en ANSI SQL
  3. Obtiene todos los registros de department_id de la tabla de empleados, ya sea que coincidan o no
  4. Obtiene todos los registros de department_id de la tabla de departamentos, ya sea que coincidan o no

Answer: A, D. La condición e.department_id (+) = d.department_id significa que realizará una unión externa derecha y todos los department_id s de la tabla de departamentos se mostrarán si coinciden o no

26.Which of the following syntax models is used in extensively in the software systems worldwide?

  1. ANSI SQL: 1999
  2. Tanto la sintaxis tradicional de Oracle como la sintaxis ANSI SQL: 1999
  3. Sintaxis tradicional de Oracle
  4. Todas las opciones

Answer: C. La sintaxis ANSI SQL: 1999, aunque no se utiliza tanto como la sintaxis tradicional de Oracle, sigue siendo una de las sintaxis que se pueden utilizar en Oracle SQL.

27.What of the following is true regarding the Cartesian product in Oracle DB?

  1. Si 'N' es el número de tablas unidas, entonces si no. de uniones es N-1, el producto cartesiano no se realiza
  2. Si 'N' es el número de tablas unidas, entonces si no. de uniones es N, se realiza un producto cartesiano
  3. Si 'N' es el número de tablas unidas, entonces si no. de uniones es N + 1, el producto cartesiano se realiza
  4. Si 'N' es el número de tablas unidas, entonces si no. de uniones es N-1 o menos, se realiza un producto cartesiano.

Answer: A. Una combinación cartesiana entre dos tablas devuelve todas las combinaciones posibles de filas de las tablas. Se puede producir una combinación cartesiana si no se incluye una operación de combinación en la consulta o si se usa CROSS JOIN. Una consulta debe tener al menos (N-1) condiciones de combinación para evitar un producto cartesiano, donde N es el número de tablas en la consulta.

28.What is the reason of error in the following SQL query? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SELECT first_name, last_name
FROM employees, departments
WHERE department_id (+) = department_id ;
  1. No se utilizan alias para las tablas.
  2. La palabra RIGHT OUTER JOIN no se usa aquí, por lo tanto, arroja el error
  3. El (+) debe estar en el lado derecho de la condición de igualdad y no en el lado izquierdo
  4. Los alias de tabla deben usarse con el department_id en la condición para eliminar los nombres ambiguos

Answer: D. Sin los alias de la tabla, Oracle no puede derivar el origen de las columnas que se unen y, por lo tanto, arroja un error de ambigüedad en la ejecución.

29.Which of the following is used to avoid the ambiguous column problem in Oracle DB?

  1. ;
  2. ,
  3. .
  4. /

Answer: C. La sintaxis para eliminar el problema de la columna ambigua es: table_alias.column_name

30.Which of the following is the most appropriate about the following query? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SELECT employee_id , first_name, last_name
FROM employees e right outer join department d
On e.department_id  = d.department_id ;
  1. Da los detalles de aquellos empleados que no están en ningún departamento
  2. Da los detalles de aquellos departamentos que no tienen ningún empleado
  3. Proporciona los detalles de todos los departamentos independientemente de si tienen algún empleado o no
  4. Da los detalles de los empleados que fueron contratados en la empresa 'ABC' independientemente de los departamentos.

Answer: C. Con el método JOIN para combinaciones externas, puede agregar las palabras clave LEFT, RIGHT o FULL. Una combinación externa izquierda incluye todos los registros de la tabla enumerada en el lado izquierdo de la combinación, incluso si no se encuentra ninguna coincidencia con la otra tabla en la operación de combinación. Una combinación externa completa incluye todos los registros de ambas tablas, incluso si no se encuentra ningún registro correspondiente en la otra tabla.

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

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SELECT *
FROM employees e, department d
WHERE a.department_id  = b.department_id ;
  1. Dará todos los valores coincidentes de ambas tablas que tienen el mismo departamento_id
  2. Le dará todas las columnas de la tabla de empleados y solo las 100 filas superiores de la tabla de departamentos.
  3. Dará un error de ORA: "b.department_id" identificador no válido
  4. Ninguna de las opciones anteriores

Answer: C. Los mismos alias deben estar en la cláusula WHERE que se declaran en la cláusula FROM

32.Which of the following is true regarding the USING and ON clauses in table joins? (Choose more than one options if applicable)

  1. La cláusula ON se puede utilizar para unir tablas en columnas con el mismo tipo de datos pero no necesariamente con el mismo nombre
  2. Las cláusulas USING y ON se utilizan solo en equijoins y no equijoins
  3. No se puede utilizar más de una condición con la cláusula ON
  4. La cláusula WHERE se puede escribir después de la cláusula USING..ON para aplicar condiciones adicionales

Answer: A, D. El enfoque JOIN ... USING es similar al enfoque NATURAL JOIN, excepto que la columna común se especifica en la cláusula USING. No se puede incluir una condición en la cláusula USING para indicar cómo se relacionan las tablas. Además, los calificadores de columna no se pueden usar para la columna común especificada en la cláusula USING. El enfoque JOIN ... ON une tablas en función de una condición especificada. La palabra clave JOIN en la cláusula FROM indica las tablas que se unirán y la cláusula ON indica cómo se relacionan las dos tablas. Este enfoque debe usarse si las tablas que se unen no tienen una columna común con el mismo nombre en cada tabla.

33.How many tables can be joined by using the JOINS in Oracle DB?

  1. 1
  2. 2
  3. 255
  4. Sin límite

Answer: D. Actualmente no hay límite en el número de mesas que participan en una combinación.

34. What is true when multiple joins are used in an SQL statement?

  1. Las uniones se evalúan de izquierda a derecha.
  2. Las uniones se evalúan de derecha a izquierda
  3. No existe precedencia en el proceso de evaluación de uniones
  4. Ninguna de las anteriores

Answer: A. Cuando existen múltiples combinaciones en una declaración, se evalúan de izquierda a derecha.

35.What is true with respect to the following query? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SQL> desc bonus
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER
 JOB_ID 			  VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
SELECT bonus, first_name, department_id 
FROM bonus b NATURAL JOIN employees e NATURAL JOIN department d;
  1. El uso de NATURAL JOIN para unir varias tablas es una mejor opción y produce resultados precisos
  2. La probabilidad de error es muy inferior cuando se utilizan JOINs NATURALES para unir varias tablas
  3. Las cláusulas USING..JOIN..ON dan resultados más precisos que NATURAL JOIN cuando se unen varias tablas
  4. Oracle une implícitamente varias tablas cuando se usa un NATURAL JOIN y, por lo tanto, es una buena práctica usar NATURAL JOINS

Answer: C. El uso de NATURAL JOINS puede crear productos cartesianos de filas y también es propenso a errores con conjuntos de resultados no confiables.

36.What is true about the clauses JOIN..ON in Oracle DB?

  1. No son muy confiables en comparación con NATURAL JOINS cuando se unen varias tablas
  2. La cláusula JOIN..ON es similar a la cláusula WHERE que limita las filas con condiciones
  3. Una cláusula adicional WHERE es obligatoria cuando se utiliza la cláusula JOIN..ON
  4. Ninguna de las anteriores

Answer: B. El enfoque JOIN .... ON une tablas en función de una condición especificada. La palabra clave JOIN en la cláusula FROM indica las tablas que se unirán y la cláusula ON indica cómo se relacionan las dos tablas. Este enfoque debe usarse si las tablas que se unen no tienen una columna común con el mismo nombre en cada tabla.

Examine the table structures as given. Answer the questions 37 and 38 that follow the query given below:

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SELECT e.salary, d.department_id 
FROM employees e JOIN department d
On (e.department_id  = d.department_id  and e.last_name = 'Brandon');

37.What is true with respect to the query given above?

  1. Da un error ORA ya que la cláusula WHERE obligatoria no está presente
  2. La cláusula JOIN..ON no puede contener más de una condición
  3. La consulta ignora la última condición y se ejecuta sin un error ORA
  4. La cláusula JOIN..ON se puede escribir en la forma dada arriba para poner más condiciones.

Answer: D. La cláusula WHERE se puede omitir y las condiciones relevantes se pueden acomodar en la cláusula JOIN..ON como se muestra en la consulta dada

38.With respect to the given query, if the JOIN used is replaced with NATURAL JOIN, it throws an error. What is the reason for this error?

  1. Cuando se usa NATURAL JOIN, una cláusula WHERE es obligatoria, omitiendo lo que da un error
  2. La cláusula ON debe reemplazarse por la cláusula USING
  3. Las palabras NATURAL, JOIN y USING son mutuamente exclusivas en el contexto de la misma cláusula de unión.
  4. Una consulta no puede combinar las cláusulas NATURAL JOIN y ON (o USING) mientras se une.

Answer: C, D.

39.What is true about Non-equijoins in Oracle DB?

  1. Se unen en función de la palabra clave NON-EQUI JOIN
  2. Se utilizan mediante la cláusula JOIN..ON con el signo "="
  3. Los resultados se obtienen cuando el resultado de la desigualdad mencionada se evalúa como verdadero.
  4. Ninguna de las anteriores

Answer: C. Las uniones no equi se utilizan con la cláusula JOIN..ON pero con operadores de desigualdad.

Examine the structures of the tables EMPLOYEES and DEPARTMENTS as given and answer the questions 40 and 41 that follow.

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

40.What will be the outcome of the following query in Oracle DB?

SELECT e.first_name, e.last_name, e.employee_id 
FROM employees e JOIN department d
ON (e.salary BETWEEN 1000 AND 10000);
  1. Lanzará un error ORA ya que la condición en la cláusula ON es incorrecta.
  2. Lanzará un error ORA debido a un error de sintaxis ya que no hay un signo de igualdad "=" en la cláusula ON
  3. Se ejecutará con éxito y dará el nombre, apellido e identificación de empleado de los empleados con la condición mencionada.
  4. Las combinaciones no equitativas solo se pueden utilizar para mostrar desigualdades y no rangos.

Answer: C.

41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?

  1. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >20000)
    AND d.loc = upper ('Geneva');
  2. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >=20000);
  3. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >=20000)
    AND d.loc = 'Geneva';
  4. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >20000)
    WHERE d.loc = upper('Geneva');

Answer: A, C.

42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?

  1. El resultado de la operación de coincidencia de desigualdad es verdadero
  2. El resultado de la operación de igualación de desigualdad es 0
  3. El resultado de la operación de igualación de desigualdad es 1
  4. El resultado de la operación de coincidencia de desigualdad es falso

Answer: A. Una unión de igualdad se crea cuando los registros de unión de datos de dos tablas diferentes son una coincidencia exacta (es decir, una condición de igualdad crea la relación). El enfoque tradicional utiliza un signo igual como operador de comparación en la cláusula WHERE. El enfoque JOIN puede utilizar las palabras clave NATURAL JOIN, JOIN ... USING o JOIN ... ON.

41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?

  1. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >20000)
    AND d.loc = upper ('Geneva');
  2. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >=20000);
  3. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >=20000)
    AND d.loc = 'Geneva';
  4. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >20000)
    WHERE d.loc = upper('Geneva');

Answer: A, C.

42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?

  1. El resultado de la operación de coincidencia de desigualdad es verdadero
  2. El resultado de la operación de igualación de desigualdad es 0
  3. El resultado de la operación de igualación de desigualdad es 1
  4. El resultado de la operación de coincidencia de desigualdad es falso

Answer: A. Una unión de igualdad se crea cuando los registros de unión de datos de dos tablas diferentes son una coincidencia exacta (es decir, una condición de igualdad crea la relación). El enfoque tradicional utiliza un signo igual como operador de comparación en la cláusula WHERE. El enfoque JOIN puede utilizar las palabras clave NATURAL JOIN, JOIN ... USING o JOIN ... ON.

41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?

  1. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >20000)
    AND d.loc = upper ('Geneva');
  2. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >=20000);
  3. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >=20000)
    AND d.loc = 'Geneva';
  4. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >20000)
    WHERE d.loc = upper('Geneva');

Answer: A, C.

42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?

  1. El resultado de la operación de coincidencia de desigualdad es verdadero
  2. El resultado de la operación de igualación de desigualdad es 0
  3. El resultado de la operación de igualación de desigualdad es 1
  4. El resultado de la operación de coincidencia de desigualdad es falso

Answer: A. Una unión de igualdad se crea cuando los registros de unión de datos de dos tablas diferentes son una coincidencia exacta (es decir, una condición de igualdad crea la relación). El enfoque tradicional utiliza un signo igual como operador de comparación en la cláusula WHERE. El enfoque JOIN puede utilizar las palabras clave NATURAL JOIN, JOIN ... USING o JOIN ... ON.

41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?

  1. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >20000)
    AND d.loc = upper ('Geneva');
  2. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >=20000);
  3. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >=20000)
    AND d.loc = 'Geneva';
  4. SELECT e.first_name, e.last_name
    FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id  and e.salary >20000)
    WHERE d.loc = upper('Geneva');

Answer: A, C.

42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?

  1. El resultado de la operación de coincidencia de desigualdad es verdadero
  2. El resultado de la operación de igualación de desigualdad es 0
  3. El resultado de la operación de igualación de desigualdad es 1
  4. El resultado de la operación de coincidencia de desigualdad es falso

Answer: A. Una unión de igualdad se crea cuando los registros de unión de datos de dos tablas diferentes son una coincidencia exacta (es decir, una condición de igualdad crea la relación). El enfoque tradicional utiliza un signo igual como operador de comparación en la cláusula WHERE. El enfoque JOIN puede utilizar las palabras clave NATURAL JOIN, JOIN ... USING o JOIN ... ON.

43.What is true regarding a Self-Join in Oracle DB?

  1. Solo se requieren dos tablas para que la unión funcione
  2. Las columnas en el conjunto de resultados se obtienen de dos tablas pero se muestran en una tabla
  3. Conceptualmente, la tabla de origen se duplica para crear la tabla de destino. (Oracle no duplica tablas)
  4. Todas las anteriores

Answer: C. Las autouniones se utilizan cuando una tabla debe unirse a sí misma para recuperar los datos que necesita. Los alias de tabla son necesarios en la cláusula FROM para realizar una autounión.

44. With respect to the query and the table structure given below,answer the question.

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 *
FROM employees a join employees b
WHERE a.employee_id  = b.employee_id ;

¿Cuál de las siguientes tablas trata Oracle como tabla de origen y tabla de destino?

  1. a es fuente yb es destino
  2. b es fuente y a es destino
  3. Oracle no trata ninguna de las tablas como fuente o destino
  4. Ninguna de las anteriores

Answer: A. La primera aparición de la tabla de empleados se toma como origen y las siguientes apariciones como b, c, etc.

45.In what scenarios can we use Self-Joins ideally in Oracle DB?

  1. Cuando necesitamos encontrar los registros duplicados en una tabla
  2. Cuando necesitamos obtener valores NULL de una tabla
  3. Cuando necesitamos mostrar una columna de una tabla dos veces
  4. Cuando necesitamos mostrar la jerarquía de entidades relevantes

Answer: D.

46. What is true about NATURAL JOINS in Oracle DB?

  1. Las columnas unidas tienen el mismo nombre pero pueden tener diferentes tipos de datos
  2. Las columnas unidas pueden tener el mismo tipo de datos pero diferentes nombres
  3. Las columnas unidas deben tener nombres idénticos y el mismo tipo de datos
  4. Ninguna de las anteriores

Answer: C. Las palabras clave NATURAL JOIN no requieren una condición para establecer la relación entre dos tablas. Sin embargo, debe existir una columna común. Los calificadores de columna no se pueden usar con las palabras clave NATURAL JOIN.

47.A report has to be extracted which gives the department name, department ID, department city and location ID only for departments 100 and 101. Using NATURAL JOINS, which of the following options will give the required results?

  1. SELECT department_id , department_name  ,location, city
    FROM departments 
    NATURAL JOIN locations 
    WHERE department_id in (100,101);
  2. SELECT department_id , department_name  ,location, city
    FROM locations 
    NATURAL JOIN departments 
    WHERE department_id BETWEEN 100 AND 101;
  3. SELECT department_id , department_name  ,location, city
    FROM departments 
    NATURAL JOIN locations 
    WHERE department_id >100
    AND department_id >101;
  4. SELECT department_id , department_name  ,location, city
    FROM departments 
    NATURAL JOIN locations ;

Answer: A. El DONDE se puede utilizar para condiciones adicionales después de la cláusula NATURAL JOIN.

48.In which of the following scenarios shall a USING clause or a NATURAL JOIN clause be used?

  1. Cuando los nombres de las columnas de las tablas sean idénticos, utilice la cláusula USING
  2. Cuando los tipos de datos de las columnas de las tablas son idénticos, utilice NATURAL JOINS
  3. Si varias columnas tienen los mismos nombres pero los tipos de datos no coinciden, se puede usar USING
  4. Las UNIONES NATURALES deben usarse solo cuando los nombres de las columnas y sus tipos de datos son los mismos

Answer: C, D. NATURAL JOINS y USING son mutuamente excluyentes, la cláusula USING debe usarse para hacer coincidir solo una columna cuando coinciden más de una columna.

49.Examine the table structures given. What will be the outcome of the following query? (Choose the most appropriate answer)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc bonus
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER
 JOB_ID 			  VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
SELECT e.name, b.bonus
FROM employees e 
JOIN bonus b
USING (job_id)
WHERE e.job_id  like 'SA%');
  1. Da los nombres y bonificaciones obtenidos por todos los empleados en alguna empresa
  2. Da los nombres y bonificaciones obtenidos por todos los empleados en un puesto de trabajo en particular en una empresa.
  3. Se ejecuta con éxito dando todos los nombres y el bono obtenido por todos los empleados en todos los puestos
  4. Lanza un error ORA.

Answer: D. Las columnas utilizadas en la cláusula USING no deben tener un calificador (nombre de tabla o alias) en ninguna parte de la declaración SQL.

50.What is true with respect to INNER JOINS and OUTER JOINS in Oracle DB?

  1. INNER JOIN devuelve solo las filas que coinciden
  2. OUTER JOIN devuelve solo las filas que no coinciden
  3. OUTER JOIN devuelve las filas que coinciden, así como las que no coinciden
  4. Ninguna de las anteriores

Answer: A, C. Una combinación puede ser una combinación interna, en la que los únicos registros devueltos tienen un registro coincidente en todas las tablas, o una combinación externa, en la que se pueden devolver registros independientemente de si hay un registro coincidente en la combinación. Una combinación externa se crea cuando los registros deben incluirse en los resultados sin tener los registros correspondientes en las tablas de combinación. Estos registros se comparan con los registros NULL para que se incluyan en la salida.

51. What is true regarding FULL OUTER JOIN in Oracle DB?

  1. Cuando tanto LEFT OUTER JOIN como RIGHT OUTER JOIN aparecen en la misma consulta, se denomina FULL OUTER JOIN
  2. Un COMPLETO OUTER JOIN es lo mismo que un OUTER JOIN
  3. Tanto a como B
  4. Una combinación entre dos tablas que devuelve los resultados de una combinación INNER y una UNIÓN EXTERIOR IZQUIERDA y DERECHA se denomina UNIÓN EXTERIOR COMPLETA

Answer: D. Una combinación externa completa incluye todos los registros de ambas tablas, incluso si no se encuentra ningún registro correspondiente en la otra tabla.

Examine the given table structures and answer the questions 52 and 53 that follow.

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

52.Consider the following query.

SELECT e.job_id , e.first_name, d.department_id 
FROM departments D JOIN employees e JOIN BONUS b
USING (job_id );

Esta consulta da como resultado un error. ¿Cuál es el motivo del error?

  1. UN JOIN..USING solo puede ocurrir entre dos tablas a la vez
  2. La cláusula USING en la consulta no tiene ninguna columna del departamento
  3. No hay una cláusula WHERE en la consulta
  4. Ninguna de las anteriores

Answer: A. Table1 JOIN table2 JOIN table3 no está permitido sin las cláusulas ON para entre cada JOIN

53.You need to display all the non-matching rows from the EMPLOYEES table and the non-matching rows from the DEPARTMENT table without giving a Cartesian product of rows between them. Which of the following queries will give the desired output?

  1. SELECT *
    FROM employees e, department d
    WHERE e.department_id  = d.department_id ;
  2. SELECT *
    FROM employees e NATURAL JOIN department d;
  3. SELECT *
    FROM employees e FULL OUTER JOIN department d
    ON  e.department_id  = d.department_id ;
  4. SELECT *
    FROM employees e JOIN  department d
    ON ( e.department_id  > d.department_id ) ;

Answer: C. FULL OUTER JOIN devuelve las filas no coincidentes de ambas tablas. Una combinación externa completa incluye todos los registros de ambas tablas, incluso si no se encuentra ningún registro correspondiente en la otra tabla.

54.Which of the following ANSI SQL: 1999 join syntax joins are supported by Oracle?

  1. Productos cartesianos
  2. Uniones naturales
  3. Unión EXTERIOR completa
  4. Equijoins

Answer: D.

55.Which of the following is not a format for Outer Joins in Oracle DB?

  1. Right
  2. Left
  3. Centre
  4. Full

Answer: C. Excepto 'Center', los 3 tipos restantes son los tipos de formatos de Outer Joins en Oracle DB. Con el método JOIN para combinaciones externas, puede agregar las palabras clave LEFT, RIGHT o FULL.

Examine the given table structures. Answer the questions 56, 57 and 58 that follow by referring to the following query:

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

56.You need to find the results obtained by the above query only for the departments 100 and 101. Which of the following clauses should be added / modified to the above query?

  1. Se debe agregar ON (e.department_id = d.department_id)
  2. Se debe agregar USING (e.department_id)
  3. DONDE e.department_id en (100,101) debe agregarse
  4. Ninguna de las anteriores

Answer: C. La cláusula NATURAL JOIN coincide implícitamente con todas las columnas con nombres idénticos. Para agregar condiciones adicionales, se puede usar la cláusula WHERE.

57.You need to find the results obtained by the above query for all those employees who have salaries greater than 20000. Which of the following clauses should be added / modified to the above query?

  1. ON (e.department_id = d.department_id) DONDE salario> 20000;
  2. USING (e.department_id) DONDE salario> 20000;
  3. USING (department_id) DONDE salario> 20000;
  4. DONDE salario> 20000;

Answer: D.

58.If the NATURAL JOIN in the above query is replaced by only JOIN which of the following should be added / modified to the above query to give the results pertaining to Department 100?

  1. ENCENDIDO (departamento_id = 100);
  2. USANDO (e.department_id = 100);
  3. DONDE d.department_id = 100;
  4. ON (e.department_id = d.department_id y d.department_id = 100);

Answer: D. Se pueden agregar equi-joins para más condiciones después de la cláusula ON.

59.A report has to be extracted to get the Managers for all the employees in the departments 10 and 20 of a company 'ABC'. Which of the following queries will give the required results? (Consider the table structure as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
  1. SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees"
    FROM employees a join employees b
    On (employee_id );
  2. SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees"
    FROM employees a join employees b
    On (b.employee_id  = a.employee_id );
  3. SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees"
    FROM employees a join employees b
    On (a.manager_id  = b.employee_id )
    WHERE department_id  in (10,20);
  4. SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees"
    FROM employees a join employees b
    On (a.manager_id  = b.employee_id )
    WHERE a.department_id  in (10,20);

Answer: D. La opción C es incorrecta porque el department_id sin alias en la cláusula WHERE arrojará un error.

60.Which of the following queries will give results without duplicate values between the two tables EMPLOYEES and DEPARTMENT? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
  1. SELECT *
    FROM employees e NATURAL JOIN department d;
  2. SELECT *
    FROM employees e JOIN department d;
  3. SELECT *
    FROM employees e NATURAL JOIN department d
    USING (e.department_id );
  4. SELECT * 
    FROM employees e FULL OUTER JOIN department d
    USING (department_id );

Answer: D. El FULL OUTER JOIN dará todas las filas coincidentes y no coincidentes de ambas tablas, excluyendo los valores duplicados.

Examine the structures for the tables as given here and answer the questions 61 to 64.

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc bonus
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER
 JOB_ID 			  VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
SQL> desc locations
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 LOCATION_ID		 NOT NULL NUMBER(4)
 STREET_ADDRESS 		  VARCHAR2(40)
 POSTAL_CODE			  VARCHAR2(12)
 CITY			 NOT NULL VARCHAR2(30)
 STATE_PROVINCE 		  VARCHAR2(25)
 COUNTRY_ID			  CHAR(2)
SQL> desc locations
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 LOCATION_ID		 NOT NULL NUMBER(4)
 STREET_ADDRESS 		  VARCHAR2(40)
 POSTAL_CODE			  VARCHAR2(12)
 CITY			 NOT NULL VARCHAR2(30)
 STATE_PROVINCE 		  VARCHAR2(25)
 COUNTRY_ID			  CHAR(2)

61.What is true about the following query? (Choose the most appropriate answer)

SELECT *
FROM bonus b, employees e
WHERE b.job_id  (+) = e.job_id ;
  1. Mostrará todas las bonificaciones obtenidas por todos los empleados.
  2. Mostrará NULL para la columna de bonificación si un empleado en particular no ha recibido ninguna bonificación.
  3. Tanto a como B
  4. Ninguna de las anteriores

Answer: B. El (+) está a la izquierda de la ecuación significa que es una UNIÓN EXTERIOR DERECHA y viceversa.

62.You have to list all the departments who have no employees yet in a company named 'XYZ'. Which of the following queries will give you the required results?

  1. SELECT department_id , department_name FROM departments d NATURAL JOIN employees e;
  2. SELECT department_id , department_name FROM employees e JOIN departments d
    ON (e.department_id  = d.department_id );
  3. SELECT department_id , department_name FROM employees e LEFT OUTER JOIN departments d
    USING (department_id );
  4. SELECT department_id , department_name FROM employees e RIGHT OUTER JOIN departments d
    ON (e.department_id  = d.department_id );

Answer: D.

63.You need to extract a report which displays 'No department yet' for all those employees who are yet to be allocated to a department. Which of the following will fulfill the purpose?

  1. SELECT nvl(department_id ,'No department yet')
    FROM employees e RIGHT OUTER JOIN departments d
    ON (e.department_id  = d.department_id );
  2. SELECT nvl(department_id ,'No department yet')
    FROM departments d LEFT OUTER JOIN employees e
    ON (e.department_id  = d.department_id );
  3. SELECT nvl(department_id ,'No department yet')
    FROM employees e LEFT OUTER JOIN departments d
    ON (e.department_id  = d.department_id );
  4. SELECT nvl(department_id ,'No department yet')
    FROM employees e FULL OUTER JOIN departments d
    ON (e.department_id  = d.department_id );

Answer: C.

64.You need to extract a report which displays all the departments which have not been assigned to a city yet. Which of the following queries will give you the required output?

  1. SELECT department_id , department_name FROM departments d NATURAL JOIN locations l;
  2. SELECT department_id , department_name FROM departments d FULL OUTTER JOIN locations l
    ON (d.location_id = l.location_id);
  3. SELECT  d.department_id , d.department_name FROM departments d JOIN locations l
    USING (location_id);
  4. SELECT department_id , department_name FROM departments d LEFT OUTER JOIN locations l
    ON (d.location_id = l.location_id);

Answer: D.

65.In which two cases an OUTER JOIN should be used?

  1. Si las columnas de las tablas unidas tienen valores NULL
  2. Si las tablas unidas tienen columnas NO NULAS
  3. Si las tablas unidas solo tienen datos que no coinciden
  4. Si las tablas unidas tienen datos coincidentes y no coincidentes

Answer: A, D. Se crea una combinación externa cuando los registros deben incluirse en los resultados sin tener los registros correspondientes en las tablas de combinación. Estos registros se comparan con los registros NULL para que se incluyan en la salida.

66.You need to find the salary grade obtained by each employee. Which of the following query will you use? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc grade
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 GRADE 				  NUMBER
 LOSAL 				  NUMBER
 HISAL				  NUMBER
  1. SELECT employee_id , salary, grade
    FROM employees e JOIN grade g
    ON g.grade BETWEEN g.losal AND g.hisal
  2. SELECT employee_id , salary, grade
    FROM employees e FULL OUTER JOIN grade g
    WHERE g.grade > g.losal AND < g.hisal;
  3. SELECT employee_id , salary, grade 
    FROM employees e JOIN grade g
    ON (MIN(g.grade) = g.losal
    AND MAX(g.grade) = g.hisal);
  4. Ninguna de las anteriores

Answer: A.

67.Examine the table structures given.

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

Evalúe esta declaración SQL:

SELECT e.employee_id , (.25* e.salary) + (.5 * e.commission_pct) + (.75 * b.bonus) as calc_val
FROM employees e, bonus b
WHERE e.employee_id  = b.employee_id ;

¿Qué pasará si quita todos los paréntesis del cálculo?

  1. El valor que se muestra en la columna calc_val será menor.
  2. El valor que se muestra en la columna calc_val será mayor.
  3. No habrá diferencia en la columna calc_val.
  4. Se informará de un error.

Answer: C.

68.Consider the exhibit and examine the structures of the EMPLOYEES, DEPARTMENTS, and GRADE tables. For which situation would you use a non-equijoin query?

  1. Para encontrar la calificación de cada uno de los empleados
  2. Para enumerar el nombre, job_id y el nombre del gerente de todos los empleados
  3. Para encontrar el nombre del departamento de los empleados.
  4. Para encontrar la cantidad de empleados que trabajan para el departamento administrativo y ganan menos de 30000

Answer: A. Una combinación de no igualdad establece una relación basada en cualquier otra condición que no sea igual. Los valores de rango usados ​​con combinaciones de no igualdad deben ser mutuamente excluyentes.

69.In which three cases would you use the USING clause? (Choose three.)

  1. Desea crear un no equijoin.
  2. Las tablas que se van a unir tienen varias columnas NULL.
  3. Las tablas que se van a unir tienen columnas con el mismo nombre y diferentes tipos de datos.
  4. Desea utilizar una combinación NATURAL, pero desea restringir el número de columnas en la condición de combinación.

Answer: C, D. El enfoque JOIN .... USING es similar al enfoque NATURAL JOIN, excepto que la columna común se especifica en la cláusula USING. No se puede incluir una condición en la cláusula USING para indicar cómo se relacionan las tablas. Además, los calificadores de columna no se pueden usar para la columna común especificada en la cláusula USING.

70.If the tables EMPLOYEES and BONUS have two columns with identical names viz: - SALARY and JOB_ID, which of the following queries are equivalent to each other? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc bonus
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER
 JOB_ID 			  VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
  1. SELECT * FROM employees E JOIN bonus B on (salary, job_id )
  2. SELECT * FROM employees E NATURAL JOIN bonus B on (salary, job_id )
  3. SELECT * FROM employees E JOIN bonus B USING (salary, job_id )
  4. SELECT * FROM employees E JOIN bonus B on (salary, job_id )

Answer: B, C.

71.Examine the table structures as given.

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

Examine las siguientes dos sentencias SQL:

Query 1
SELECT first_name,department_id 
FROM employees E JOIN departments D
USING (department_id );
Query 2
SELECT first_name,department_id 
FROM employees E NATURAL JOIN departments D
USING (department_id );

¿Qué afirmación es verdadera con respecto al resultado?

  1. Solo la consulta 1 se ejecuta correctamente y da el resultado requerido.
  2. Solo la consulta 2 se ejecuta correctamente y da el resultado requerido.
  3. Ambas consultas 1 y 2 se ejecutan correctamente y dan resultados diferentes.
  4. Ambas consultas 1 y 2 se ejecutan correctamente y dan el mismo resultado requerido.

Answer: D.

72.You need to generate a report showing the department location along with the employee name for all hires made before 20th January, 2013.

Emite la siguiente consulta:

SELECT department_name  , first_name||' '||last_name
FROM employees E JOIN department d
ON ( hire_date < '20-JAN-2013')
JOIN locations L
ON  (l.location_id = d.location_id) ;

¿Qué afirmación es verdadera con respecto a la consulta anterior?

  1. Se ejecuta con éxito y da el resultado requerido.
  2. Se ejecuta con éxito pero no da el resultado requerido.
  3. Produce un error porque el orden de unión de las tablas es incorrecto.
  4. Produce un error porque las condiciones de equijoin y no equijoin no se pueden usar en la misma instrucción SELECT.

Answer: B.

73.Examine the structure of the EMPLOYEES table:

Desea averiguar si los detalles de algún empleado se han ingresado más de una vez utilizando diferentes EMPLOYEE_ID, enumerando todos los nombres duplicados. ¿Qué método puede utilizar para obtener el resultado requerido?

  1. self-join
  2. unión externa completa con unión automática
  3. unión externa izquierda con unión automática
  4. unión externa derecha con unión automática

Answer: A. Las autouniones se utilizan cuando una tabla debe unirse a sí misma para recuperar los datos que necesita. Los alias de tabla son necesarios en la cláusula FROM para realizar una autounión.

Examine the structure of the tables DEPARTMENTS and LOCATIONS and answer the questions 74 and 75 that follow.

SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
SQL> desc locations
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 LOCATION_ID		 NOT NULL NUMBER(4)
 STREET_ADDRESS 		  VARCHAR2(40)
 POSTAL_CODE			  VARCHAR2(12)
 CITY			 NOT NULL VARCHAR2(30)
 STATE_PROVINCE 		  VARCHAR2(25)
 COUNTRY_ID			  CHAR(2)

74.You need to find out the departments that have not been allocated any location. Which query would give the required result?

  1. SELECT d.department_id , d.department_name FROM departments d JOIN locations l
    ON (d.location_id = l.location_id);
  2. SELECT d.department_id , d.department_name FROM departments d RIGHT OUTER JOIN locations l
    ON (d.location_id = l.location_id);
  3. SELECT d.department_id , d.department_name FROM departments d FULL JOIN locations l
    ON (d.location_id = l.location_id);
  4. SELECT d.department_id , d.department_name FROM departments d LEFT OUTER JOIN locations l
    ON (d.location_id = l.location_id);

Answer: B.

75.You want to list all departments that are not located in any location along with the department name. Evaluate the following query:

SELECT d.department_id , d.department_name  ,l.location_id, l.city
FROM departments D __________________   location L 
ON (d.location_id = l.location_id);

¿Qué dos opciones de JOIN se pueden usar en el espacio en blanco en la consulta anterior para dar el resultado correcto?

  1. JOIN
  2. UNIÓN NATURAL
  3. IZQUIERDA COMBINACIÓN EXTERNA
  4. UNIÓN EXTERIOR DERECHA

Answer: A, C.

76. You need to generate a report that shows all department IDs, with corresponding employees (if any) and bonus details (if any), for all employees. Which FROM clause gives the required result? (Consider the table structures as given)

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> desc bonus
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER
 JOB_ID 			  VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
  1. DESDE departamentos IZQUIERDA EXTERIOR ÚNETE a empleados USANDO (department_id) Bono COMPLETO DE UNIÓN EXTERIOR
  2. Departamento de unión externa completa USANDO (department_id);
  3. DESDE el bono ÚNETE a los empleados USANDO (job_id)
  4. DESDE los empleados UNIRSE COMPLETAMENTE A los departamentos Bono COMPLETO DE UNIRSE EXTERIOR

Answer: A.

77. Examine the following exhibits:

Desea generar un informe que enumere las identificaciones de los empleados y sus comisiones y departamentos correspondientes (si los hay), si las comisiones existen o no. Evalúe la siguiente consulta:

SELECT e.employee_id , bonus, department_name FROM bonus b_____________ employees
USING (job_id ) ____________ departments 
USING (department_id )
WHERE commission_pct  IS NOT NULL;

¿Qué combinación de combinaciones utilizadas en los espacios en blanco de la consulta anterior da el resultado correcto?

  1. UNIRSE; IZQUIERDA COMBINACIÓN EXTERNA
  2. UNIÓN EXTERIOR COMPLETA; UNIÓN EXTERIOR COMPLETA
  3. UNIÓN EXTERIOR DERECHA; IZQUIERDA COMBINACIÓN EXTERNA
  4. IZQUIERDA COMBINACIÓN EXTERNA; UNIÓN EXTERIOR DERECHA

Answer: A.

78.Predict the outcome of the following query.

SELECT e.salary, bonus
FROM employees E JOIN bonus b
USING (salary,job_id );
  1. Se ejecuta con éxito.
  2. Lanza un error porque la bonificación en SELECT no tiene alias
  3. Lanza un error porque la cláusula USING no puede tener más de 1 columna.
  4. Se ejecuta con éxito pero los resultados no son correctos.

Answer: D.

View the Exhibit and examine the structure of the EMPLOYEES, DEPARTMENTS, LOCATIONS and BONUS. Answer the questions from 79 and 80 that follow:

79.You need to list all the departments in the city of Zurich. You execute the following query:

SELECT D.DEPARTMENT_ID , D.DEPARTMENT_NAME  , L.CITY
FROM departments D JOIN LOCATIONS L
USING (LOC_ID,CITY) 
WHERE L.CITY = UPPER('ZURICH');

Predecir el resultado de la consulta anterior.

  1. Se ejecuta con éxito.
  2. Da un error porque se usa un calificador para CITY en la instrucción SELECT.
  3. Da un error porque los nombres de las columnas en SELECT no coinciden
  4. Da un error porque la cláusula USING tiene CITY que no es una columna coincidente.

Answer: D. Solo los nombres de columna coincidentes deben usarse en la cláusula USING.

80.Answer the question that follows the query given below:

SELECT e.first_name, d.department_id , e.salary, b.bonus
FROM bonus b join employees e
USING (job_id )
JOIN department d
USING (department_id )
WHERE d.loc = 'Zurich';

Debe extraer un informe que proporcione el nombre, número de departamento, salario y bonificaciones de los empleados de una empresa llamada 'ABC'. ¿Cuál de las siguientes consultas resolverá el propósito?

  1. SELECT e.first_name, d.department_id , e.salary, b.bonus
    FROM bonus b join employees e join departments d
    on (b.job_id  = e.job_id )
    on (e.department_id =d.department_id )
    WHERE d.loc = 'Zurich';
  2. SELECT e.first_name, d.department_id , e.salary, b.bonus
    FROM bonus b join employees e
    on (b.job_id  = e.job_id )
    JOIN department d
    on (e.department_id =d.department_id )
    WHERE d.loc = 'Zurich';
  3. SELECT e.first_name, d.department_id , e.salary, b.bonus
    FROM employees e join bonus b
    USING (job_id )
    JOIN department d
    USING (department_id )
    WHERE d.loc = 'Zurich';
  4. Ninguna de las anteriores

Answer: C. La consulta A arrojará un error sintáctico, la consulta B arrojará un error de identificador no válido entre la bonificación y el departamento.

Examine the Exhibits given below and answer the questions 81 to 85 that follow.

81. You need to find the managers' name for those employees who earn more than 20000. Which of the following queries will work for getting the required results?

  1. SELECT e.employee_id  "Employee", salary, employee_id , 
    FROM employees E JOIN employees M
    USING (e.manager_id  = m.employee_id )
    WHERE e.salary >20000;
  2. SELECT e.employee_id  "Employee", salary, employee_id , 
    FROM employees E JOIN employees M
    USING (e.manager_id)
    WHERE e.salary >20000;
  3. SELECT e.employee_id  "Employee", salary, employee_id , 
    FROM employees E  NATURAL JOIN employees M
    USING (e.manager_id = m.employee_id )
    WHERE e.salary >20000;
  4. SELECT e.employee_id  "Employee", salary, employee_id , 
    FROM employees E JOIN employees M
    ON (e.manager_id = m.employee_id )
    WHERE e.salary >20000;

Answer: D.

82.You issue the following query:

SELECT e.employee_id ,d.department_id 
FROM employees e NATURAL JOIN department d NATURAL JOIN bonus b
WHERE department_id  =100;

¿Qué afirmación es verdadera con respecto al resultado de esta consulta?

  1. Se ejecuta con éxito.
  2. Produce un error porque la combinación NATURAL solo se puede usar con dos tablas.
  3. Produce un error porque una columna utilizada en la combinación NATURAL no puede tener un calificador.
  4. Produce un error porque todas las columnas utilizadas en la combinación NATURAL deben tener un calificador.

Answer: C.

83.You want to display all the employee names and their corresponding manager names. Evaluate the following query:

SELECT e.first_name "EMP NAME", m.employee_name "MGR NAME"
FROM employees e ______________ employees m
ON e.manager_id = m.employee_id ;

¿Qué opción de JOIN se puede usar en el espacio en blanco en la consulta anterior para obtener el resultado requerido?

  1. UNIRSE interior simple
  2. UNIÓN EXTERIOR COMPLETA
  3. IZQUIERDA COMBINACIÓN EXTERNA
  4. UNIÓN EXTERIOR DERECHA

Answer: C. Una combinación externa izquierda incluye todos los registros de la tabla enumerada en el lado izquierdo de la combinación, incluso si no se encuentra ninguna coincidencia con la otra tabla en la operación de combinación.

Consider the below exhibit and following query to answer questions 84 and 85. (Assume the table department has manager_id and department_name as its columns)

Select *
FROM employees e JOIN department d
ON (e.employee_id  = d.manager_id);

84. You need to display a sentence "(first_name) (last_name) is manager of the (department_name) department". Which of the following SELECT statements will successfully replace '*' in the above query to fulfill this requirement?

  1. SELECT e.first_name||' '||e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
  2. SELECT e.first_name, e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
  3. SELECT e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
  4. Ninguna de las anteriores

Answer: A.

85.What will happen if we omit writing the braces "( )" after the ON clause in the above query?

  1. Dará solo los nombres de los empleados y los nombres de los gerentes se excluirán del conjunto de resultados
  2. Dará el mismo resultado que con llaves "()"
  3. Dará un error ORA ya que es obligatorio escribir las llaves "()" cuando se usa la cláusula JOIN..ON
  4. Ninguna de las anteriores

Answer: B. Las llaves no son obligatorias, pero su uso proporciona una legibilidad clara de las condiciones que contiene.

86. Which of the following queries creates a Cartesian join?

  1. SELECT title, authorid FROM books, bookauthor;
  2. SELECT title, name FROM books CROSS JOIN publisher;
  3. SELECT title, gift FROM books NATURAL JOIN promotion;
  4. Todas las anteriores

Answer: A, B. Una combinación cartesiana entre dos tablas devuelve todas las combinaciones posibles de filas de las tablas. Se puede producir una combinación cartesiana si no se incluye una operación de combinación en la consulta o si se usa CROSS JOIN.

87. Which of the following operators is not allowed in an outer join?

  1. AND
  2. =
  3. OR
  4. >

Answer: C. Oracle genera la excepción "ORA-01719: operador de combinación externa (+) no permitido en el operando de OR o IN"

88. Which of the following queries contains an equality join?

  1. SELECT title, authorid FROM books, bookauthor WHERE books.isbn = bookauthor.isbn AND retail > 20;
  2. SELECT title, name FROM books CROSS JOIN publisher;
  3. SELECT title, gift FROM books, promotion WHERE retail >= minretail AND retail <= maxretail;
  4. Ninguna de las anteriores

Answer: A. Una unión de igualdad se crea cuando los registros de unión de datos de dos tablas diferentes coinciden exactamente (es decir, una condición de igualdad crea la relación).

89. Which of the following queries contains a non-equality join?

  1. SELECT title, authorid FROM books, bookauthor WHERE books.isbn = bookauthor.isbn AND retail > 20;
  2. SELECT title, name FROM books JOIN publisher USING (pubid);
  3. SELECT title, gift FROM books, promotion WHERE retail >= minretail AND retail <= maxretail;
  4. Ninguna de las anteriores

Answer: D. Los no quijoins coinciden con los valores de columna de diferentes tablas en función de una expresión de desigualdad. El valor de la columna de combinación en cada fila de la tabla de origen se compara con los valores correspondientes en la tabla de destino. Se encuentra una coincidencia si la expresión utilizada en la combinación, basada en un operador de desigualdad, se evalúa como verdadera. Cuando se construye una combinación de este tipo, se realiza una no combinación. Una no combinación se especifica utilizando la sintaxis JOIN..ON, pero la condición de combinación contiene un operador de desigualdad en lugar de un signo igual.

90. The following SQL statement contains which type of join?

SELECT title, order#, quantity
FROM books FULL OUTER JOIN orderitems
ON books.isbn = orderitems.isbn;
  1. equality
  2. self-join
  3. non-equality
  4. unión externa

Answer: D. Una combinación externa completa incluye todos los registros de ambas tablas, incluso si no se encuentra ningún registro correspondiente en la otra tabla.

91. Which of the following queries is valid?

  1. SELECT b.title, b.retail, o.quantity FROM books b NATURAL JOIN orders od NATURAL JOIN orderitems o WHERE od.order# = 1005;
  2. SELECT b.title, b.retail, o.quantity FROM books b, orders od, orderitems o WHERE orders.order# = orderitems.order# AND orderitems.isbn=books.isbn AND od.order#=1005;
  3. SELECT b.title, b.retail, o.quantity FROM books b, orderitems o WHERE o.isbn = b.isbn AND o.order#=1005;
  4. Ninguna de las anteriores

Answer: C. Si las tablas de las combinaciones tienen un alias, las columnas seleccionadas deben referirse con el alias y no con los nombres reales de la tabla.

92. Given the following query.

SELECT zip, order#
FROM customers NATURAL JOIN orders;

¿Cuál de las siguientes consultas es equivalente?

  1. SELECT zip, order# FROM customers JOIN orders WHERE customers.customer# = orders.customer#;
  2. SELECT zip, order# FROM customers, orders WHERE customers.customer# = orders.customer#;
  3. SELECT zip, order# FROM customers, orders WHERE customers.customer# = orders.customer# (+);
  4. Ninguna de las anteriores

Answer: B. La unión natural indica a Oracle que identifique columnas con nombres idénticos entre las tablas de origen y destino.

93. Examine the table structures as given. Which line in the following SQL statement raises an error?

SQL> DESC employees
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 EMPLOYEE_ID		 NOT NULL NUMBER(6)
 FIRST_NAME			  VARCHAR2(20)
 LAST_NAME		 NOT NULL VARCHAR2(25)
 EMAIL			 NOT NULL VARCHAR2(25)
 PHONE_NUMBER			  VARCHAR2(20)
 HIRE_DATE		 NOT NULL DATE
 JOB_ID 		 NOT NULL VARCHAR2(10)
 SALARY 			  NUMBER(8,2)
 COMMISSION_PCT 		  NUMBER(2,2)
 MANAGER_ID			  NUMBER(6)
 DEPARTMENT_ID			  NUMBER(4)
SQL> DESC departments
 Name			 Null?	  Type
 ----------------------- -------- ----------------
 DEPARTMENT_ID		 NOT NULL NUMBER(4)
 DEPARTMENT_NAME	 NOT NULL VARCHAR2(30)
 MANAGER_ID			  NUMBER(6)
 LOCATION_ID			  NUMBER(4)
1. SELECT e.first_name, d.department_name
2. FROM employees  e, department d
3. WHERE e.department_id=d.department_id
  1. línea 1
  2. línea 2
  3. línea 3
  4. Sin errores

Answer: A. Si una consulta usa nombres de alias en la condición de unión, su columna debe usar el alias como referencia.

94. Given the following query:

SELECT lastname, firstname, order#
FROM customers LEFT OUTER JOIN orders
USING (customer#)
ORDER BY customer#;

¿Cuál de las siguientes consultas devuelve los mismos resultados?

  1. SELECT lastname, firstname, order# FROM customers c OUTER JOIN orders o ON c.customer# = o.customer# ORDER BY c.customer#;
  2. SELECT lastname, firstname, order# FROM orders o RIGHT OUTER JOIN customers c ON c.customer# = o.customer# ORDER BY c.customer#;
  3. SELECT lastname, firstname, order# FROM customers c, orders o WHERE c.customer# = o.customer# (+) ORDER BY c.customer#;
  4. Ninguna de las anteriores

Answer: B, C.

95. Which of the below statements are true?

  1. Las funciones de grupo no se pueden usar con los datos de múltiples fuentes de datos.
  2. Si varias tablas unidas en una consulta contienen columnas idénticas, Oracle selecciona solo una de ellas.
  3. La unión natural se utiliza para unir filas de dos tablas basadas en columnas idénticas.
  4. A y B

Answer: C. Las funciones de grupo se pueden utilizar en una consulta mediante combinaciones de Oracle. Se debe hacer referencia a las columnas ambiguas mediante un calificador.

96. Which line in the following SQL statement raises an error?

1. SELECT name, title
2. FROM books JOIN publisher
3. WHERE books.pubid = publisher.pubid
4. AND
5. cost < 45.95
  1. línea 1
  2. línea 2
  3. línea 3
  4. línea 4

Answer: C. Dado que las tablas se unen usando la palabra clave JOIN, la condición de igualdad debe escribirse con la cláusula USING y no con la cláusula WHERE.

97. Given the following query:

SELECT title, gift
FROM books CROSS JOIN promotion;

¿Cuál de las siguientes consultas es equivalente?

  1. SELECT title, gift
    FROM books NATURAL JOIN promotion;
  2. SELECT title
    FROM books INTERSECT
    SELECT gift
    FROM promotion;
  3. SELECT title
    FROM books UNION ALL
    SELECT gift
    FROM promotion;
  4. SELECT title, gift
    FROM books, promotion;

Answer: D. Las uniones cartesianas son las mismas que las uniones cruzadas.

98. If the CUSTOMERS table contains seven records and the ORDERS table has eight records, how many records does the following query produce?

SELECT *
FROM customers CROSS JOIN orders;
  1. 0
  2. 56
  3. 7
  4. 15

Answer: B. La unión cruzada es el producto cruzado de las filas contenidas en las dos tablas.

99. Which of the following SQL statements is not valid?

  1. SELECT b.isbn, p.name
    FROM books b NATURAL JOIN publisher p;
  2. SELECT isbn, name
    FROM books b, publisher p
    WHERE b.pubid = p.pubid;
  3. SELECT isbn, name
    FROM books b JOIN publisher p
    ON b.pubid = p.pubid;
  4. SELECT isbn, name
    FROM books JOIN publisher
    USING (pubid);

Answer: A. Las columnas ambiguas deben referirse con los calificadores de la tabla.

100. Which of the following lists all books published by the publisher named 'Printing Is Us'?

  1. SELECT title
    FROM books NATURAL JOIN publisher
    WHERE name = 'PRINTING IS US';
  2. SELECT title
    FROM books, publisher
    WHERE pubname = 1;
  3. SELECT *
    FROM books b, publisher p
    JOIN tables ON b.pubid = p.pubid
    WHERE name = 'PRINTING IS US';
  4. Ninguna de las anteriores

Answer: A. Suponiendo que la columna NAME no está incluida en la tabla BOOKS, la consulta A es válida.

101. Which of the following SQL statements is not valid?

  1. SELECT isbn
    FROM books
    MINUS
    SELECT isbn
    FROM orderitems;
  2. SELECT isbn, name
    FROM books, publisher
    WHERE books.pubid (+) = publisher.pubid (+);
  3. SELECT title, name
    FROM books NATURAL JOIN publisher
  4. Todas las declaraciones SQL anteriores son válidas.

Answer: B. La consulta B genera una excepción "ORA-01468: un predicado puede hacer referencia solo a una tabla unida externamente".

102. Which of the following statements about an outer join between two tables is true?

  1. Si la relación entre las tablas se establece con una cláusula WHERE, ambas tablas pueden incluir el operador de combinación externa.
  2. Para incluir registros no coincidentes en los resultados, el registro se empareja con un registro NULL en la tabla deficiente.
  3. Las palabras clave RIGHT, LEFT y FULL son equivalentes.
  4. Todas las anteriores

Answer: B.

103. Which line in the following SQL statement raises an error?

1. SELECT name, title
2. FROM books b, publisher p
3. WHERE books.pubid = publisher.pubid
4. AND
5. (retail > 25 OR retail-cost > 18.95);
  1. línea 1
  2. línea 3
  3. línea 4
  4. línea 5

Answer: B. Dado que las tablas utilizadas en la consulta tienen un calificador, las columnas deben referirse utilizando el mismo.

104. What is the maximum number of characters allowed in a table alias?

  1. 10
  2. 155
  3. 255
  4. 30

Answer: D. El alias de la tabla puede tener un máximo de 30 caracteres.

105. Which of the following SQL statements is valid?

  1. SELECT books.title, orderitems.quantity
    FROM books b, orderitems o
    WHERE b.isbn= o.ibsn;
  2. SELECT title, quantity
    FROM books b JOIN orderitems o;
  3. SELECT books.title, orderitems.quantity
    FROM books JOIN orderitems
    ON books.isbn = orderitems.isbn;
  4. Ninguna de las anteriores

Answer: C.