Preguntas sobre manipulación de datos
1.What does ACID mean with respect to relational database?
- Precisión, coherencia, aislamiento, base de datos
- Precisión, simultaneidad, aislamiento, durabilidad
- Atomicidad, consistencia, aislamiento, durabilidad
- Atomicidad, concurrencia, aislamiento, durabilidad
Answer: C. Todas las transacciones de Oracle cumplen con las propiedades básicas de una transacción de base de datos, conocidas como propiedades ACID. La atomicidad establece que todas las tareas de una transacción se realizan o ninguna de ellas. No hay transacciones parciales. La coherencia implica que la transacción lleva la base de datos de un estado coherente a otro estado coherente. Aislamiento significa que el efecto de una transacción no es visible para otras transacciones hasta que se confirma la transacción. Durabilidad significa que los cambios realizados por transacciones comprometidas son permanentes. Una vez que se completa una transacción, la base de datos garantiza a través de sus mecanismos de recuperación que los cambios de la transacción no se pierdan.
2. What does the word DML stands for in Oracle SQL?
- Lenguaje de gestión de durabilidad
- Lenguaje de gestión de bases de datos
- Lenguaje de manipulación de bases de datos
- Ninguna de las anteriores
Answer: C. DML son las siglas de Data Manipulation Language.
3. Which of the following are DML commands in Oracle Database?
- SELECT
- AGRUPAR POR
- INTERSECT
- INSERT
Answer: A, D. En términos estrictos, SELECT es un comando DML ya que es una de las cláusulas obligatorias para la manipulación de datos presentes en tablas.
4.Which of the following DML commands can be considered to be a hybrid of INSERT and UPDATE in a single statement?
- INTERSECT
- INSERT
- SELECT
- MERGE
Answer: D. MERGE puede realizar acciones INSERT y UPDATE en una sola instrucción en Oracle.
5. What all operations can MERGE statement perform in SQL?
- INSERT
- DELETE
- AGRUPAR POR
- Ninguna de las anteriores
Answer: A, B. En algunas condiciones, MERGE también puede realizar la operación DELETE, junto con INSERT y UPDATE.
6.Which of following commands is a DDL (Data Definition Language) command but is often considered along with DML commands?
- DELETE
- INSERT
- TRUNCATE
- Ninguna de las anteriores
Answer: C. TRUNCATE es un comando DDL. Elimina los registros de la tabla sin ninguna condición. No es parte de ninguna transacción en curso y una transacción no confirmada en la sesión se confirma después de que se ejecuta TRUNCATE.
7.Which of the following commands manipulate data basically?
- MINUS
- UPDATE
- TRUNCATE
- Todas las anteriores
Answer: B, C. UPDATE es una declaración DML para modificar el valor de una columna en una tabla. TRUNCATE manipula los datos eliminándolos incondicionalmente de una tabla.
8. Which of the following commands is used to populate table rows with data?
- DELETE
- INSERT
- SELECT
- UPDATE
Answer: B. El comando INSERT se usa para insertar filas en una tabla.
9. What is true about the INSERT statement? (Choose the most appropriate answer)
- Puede insertar datos en una fila de una tabla a la vez.
- Puede insertar datos en muchas filas de una tabla a la vez.
- Puede insertar datos en muchas filas de muchas tablas a la vez.
- Todas las anteriores
Answer: C. La instrucción INSERT es capaz de insertar una fila o un conjunto de filas en una sola tabla a la vez.
10.What is true about the insertion of rows in tables?
- Las filas se pueden insertar aleatoriamente
- Se puede insertar cualquier número de filas en una tabla sin restricciones
- Generalmente, las filas se insertan en una tabla según ciertas reglas conocidas como restricciones.
- Todas las anteriores
Answer: C. Las restricciones son reglas comerciales que se imponen a las columnas para garantizar el comportamiento de los datos que ingresan en la columna. Estas restricciones se validan para los datos durante el proceso INSERT.
11. What is true about the INSERT statement in Oracle SQL? (Choose the most appropriate answer)
- Una instrucción INSERT puede anular cualquier restricción puesta en la tabla
- No se puede usar una instrucción INSERT en una tabla si ya se ha colocado una restricción en la tabla
- Una instrucción INSERT se puede usar en una tabla solo si ya se ha colocado una restricción en la tabla
- Una instrucción INSERT nunca puede insertar una fila que viole una restricción.
Answer: D. Oracle genera una excepción si alguno de los datos contenidos en la declaración de inserción viola la restricción.
Consider the following data set from the EMPLOYEES table along with its structure and answer the questions 12, 13 and 14:
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)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE CLERK
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
12. Examine the structure of the EMPLOYEES table. You issue the following command:
INSERT INTO EMPLOYEES (employee_id , first_name , job_id) VALUES (5100, 'BRUCE', 'CLERK');
Suponiendo que hay una restricción de verificación de valor duplicado en la columna EMPLOYEE_ID, ¿cuál será el resultado de la declaración anterior?
- Insertará otra fila con 5100 valores BRUCE CLERK
- Insertará otra fila con 51002 valores BRUCE CLERK
- Lanzará un error ORA 'Restricción violada'
- Ninguna de las anteriores
Answer: C. Como la fila con los valores "5100, BRUCE, CLERK" ya existe en la tabla, la instrucción de inserción con el mismo conjunto de datos no es posible.
13.You issue the following command to the data set shown above:
INSERT INTO EMPLOYEES (employee_id , first_name , job_id) VALUES (51003,'BRUCE','CLERK');
¿Cuál será el resultado de esta declaración?
- Insertará una nueva fila con 51003 valores BRUCE CLERK
- Lanzará un error ORA ya que no puede haber otro BRUCE que sea un CLERK
- Lanzará un error ORA 'Restricción violada'
- Ninguna de las anteriores
Answer: A. Como no hay restricciones en las columnas FIRST_NAME y job_id, el INSERT funcionará sin ningún error.
14. You issue the following command to the data set shown above:
INSERT INTO EMPLOYEES (employee_id , first_name , job_id ) VALUES (51003,'BRUCE', NULL);
¿Cuál será el resultado de esta declaración?
- Insertará una nueva fila con 51003 valores BRUCE CLERK
- Lanzará un error ORA ya que no puede haber otro BRUCE que sea un CLERK
- Lanzará un error ORA 'Restricción violada'
- Insertará una nueva fila con 51003 BRUCE NULL valores
Answer: D. Como no hay ninguna restricción NOT NULL en las columnas FIRST_NAME y JOB_ID, se insertará el valor NULL.
15. What among the following can be said regarding inserting of rows in tables?
- El usuario no puede insertar filas de forma interactiva
- Se puede escribir una consulta con variables de sustitución para una inserción interactiva de filas por parte de los usuarios
- Cuando se le solicita a un usuario que inserte filas, la inserción no funciona y arroja un error ORA
- Ninguna de las anteriores
Answer: B. Una instrucción INSERT puede hacer uso de una variable de sustitución para solicitar al usuario que ingrese valores durante el tiempo de ejecución. Proporciona una forma interactiva de insertar datos en tablas.
16.Which of the following can be used to insert rows in tables?
- SELECT
- INSERT
- Sub-queries
- Todas las anteriores
Answer: D. La instrucción INSERT puede hacer uso explícito de INSERT, INSERT-SELECT o un método de subconsulta para insertar datos en tablas.
17. Which among the following is a common technique for inserting rows into a table? (Choose the most sensible and appropriate answer)
- Usando la cláusula SELECT
- Escribir manualmente cada valor en la cláusula INSERT
- Usar operadores SET
- Ninguna de las anteriores
Answer: A. El uso de la cláusula SELECT es la técnica más común para insertar filas en tablas. Reduce el esfuerzo de introducir valores manualmente para cada columna.
18.Which of the following commands is used to change the rows that already exist in a table?
- INSERT
- UNION
- UPDATE
- SELECT
Answer: C. UPDATE es una declaración DML que se utiliza para modificar los valores de columna en una tabla.
19.What is true about the UPDATE command?
- Puede actualizar solo una fila a la vez
- Puede actualizar solo 100 filas a la vez
- Puede actualizar filas ilimitadas a la vez de forma masiva
- Ninguna de las anteriores
Answer: C. Una ACTUALIZACIÓN puede actualizar varias filas en una o más filas a la vez según las condiciones de la cláusula WHERE.
20.Which of the following clauses decides how many rows are to be updated?
- SELECT
- WHERE
- FROM
- Todas las anteriores
Answer: B. La declaración UPDATE hace uso de la cláusula WHERE para capturar el conjunto de filas que debe actualizarse.
21.What among the following is true about the UPDATE statement? (Choose the most appropriate answer)
- Una ACTUALIZACIÓN puede actualizar filas de una sola tabla
- Una ACTUALIZACIÓN puede actualizar filas de varias tablas
- Un solo comando UPDATE no puede afectar filas en varias tablas
- Ninguna de las anteriores
Answer: A, C. Una instrucción UPDATE afecta a las filas de una sola tabla y no a varias tablas.
Consider the following data set from the EMPLOYEES table and its structure. Answer questions 22 to 24 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)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE CLERK
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
22. You need to change the JOB_ID for Bruce (Employee Id 7389) to 'ACCOUNTANT'. Which of the following statements will you fire?
UPDATE employees SET job_id = 'ACCOUNTANT' WHERE employee_id = 7389;
INSERT INTO EMPLOYEES (employee_id , first_name , job_id ) VALUES (5100,'BRUCE', 'ACCOUNTANT');
UPDATE employees SET job_id = 'ACCOUNTANT' WHERE job_id = 'CLERK';
UPDATE employees SET job_id = 'ACCOUNTANT';
Answer: A. La opción B falla porque modifica el código de trabajo de todos los empleados a CONTABLE. La opción C es incorrecta porque actualiza el código de trabajo a CONTABLE para todos los empleados de la tabla.
Answer the following questions 23 and 24 based on the below actions -
Emite la siguiente consulta a la tabla EMPLOYEES con el conjunto de datos como se muestra arriba.
UPDATE employees
Set job_id = NULL
Where employee_id = 51000;
El conjunto de datos será como se muestra a continuación: (Suponga que hay una restricción de valor duplicado en la columna EMPLOYEE_ID)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
23. Suppose you fire an UPDATE statement to update Bruce's JOB_ID to 'SALESMAN' (with respect to the data set shown above). What will be the outcome of the query?
- El código de trabajo de Bruce seguirá siendo NULO
- El código de trabajo de Bruce se modificará a 'VENDEDOR'
- Error de ORA
- Ninguna acción
Answer: B. La ACTUALIZACIÓN agregará el nuevo valor al valor NULO cambiando el NULL al nuevo valor
24. You issue an UPDATE statement to update the employee id 7389 to 7900. You query the employee by its id '7389' before committing the transaction. What will be the outcome?
- La actualización funcionará correctamente, mientras que seleccionar mostrará 7389.
- La actualización funcionará correctamente, mientras que la selección no mostrará registros.
- La restricción en EMPLOYEE_ID no permitirá que se actualice
- Se actualizará correctamente, pero todos los valores de EMPLOYEE_ID 7389 se convertirán en NULL.
Answer: B. Una consulta en una sesión es coherente con las transacciones en curso. Si la misma consulta se hubiera ejecutado en una sesión diferente, habría mostrado el registro del empleado con la identificación 7389 porque la transacción activa en la primera sesión aún no se ha confirmado.
25. What among the following is a typical use of an UPDATE statement? (Select the most appropriate answer)
- Para recuperar una fila y actualizar una o más columnas de esa fila
- Para modificar todas las filas de algunas columnas
- Para modificar todas las filas de todas las columnas de una tabla
- Ninguna de las anteriores
Answer: A. Aunque, la instrucción UPDATE puede modificar todos los valores de columna en todas las filas, normalmente se usa para seleccionar una fila y actualizar una o más columnas.
26. Which of the following practices appropriately describe for selecting which row set to update using the UPDATE statement?
- Si se van a actualizar algunas filas, se puede utilizar la restricción PRIMARY KEY
- Si se van a actualizar todas las filas, se puede considerar la cláusula WHERE
- Para actualizar un conjunto de filas use WHERE, para actualizar todas las filas de una tabla, coloque una restricción PRIMARY KEY en la tabla
- Ninguna de las anteriores
Answer: C.
27. Which of the following columns in a table are not usually updated?
- Columnas de tipo LARGO en la tabla
- Columnas LOB en la tabla
- Una columna de clave principal que también sirve como referencia de clave externa en otra tabla
- Todas las anteriores
Answer: C. Como práctica común, las columnas de clave primaria que sirven como referencia de clave externa en otras tablas, no deben actualizarse. Aunque se pueden actualizar aplazando las restricciones, lo que generalmente no se recomienda.
Consider the following data set and structure of the EMPLOYEES table and answer the questions 28 and 29 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)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE NULL
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
28. You issue an UPDATE statement as follows:
UPDATE employees
SET job_id = NULL;
¿Cuál será el resultado de la declaración anterior?
- La primera fila del conjunto de datos se actualizará a NULL
- La tercera columna de la primera fila se actualizará a NULL
- La tercera columna de todas las filas se actualizará a NULL
- Y se lanzará un error de ORA
Answer: C. Una instrucción UPDATE sin una cláusula WHERE actualizará todas las filas de la tabla.
29. You issue an UPDATE statement as follows:
UPDATE employees
SET employee_id = NULL;
WHERE job_id = 'CLERK';
¿Cuál será el resultado de la declaración anterior? (Aquí la columna EMPLOYEE_ID está marcada como obligatoria poniendo una restricción)
- La primera columna del conjunto de datos se actualizará a NULL
- La tercera columna de la primera fila se actualizará a NULL
- La tercera columna de todas las filas se actualizará a NULL
- Y se lanzará un error de ORA
Answer: D. Las restricciones de la columna deben cumplirse al actualizar su valor. En la instrucción UPDATE dada, se generará un error porque la columna EMPLOYEE_ID es una clave principal en la tabla EMPLOYEES, lo que significa que no puede ser NULL.
30. Which of the following commands can be used to remove existing records from a table?
- UPDATE
- INSERT
- MINUS
- DELETE
Answer: D. ELIMINAR se utiliza para eliminar los registros de la tabla que, opcionalmente, se pueden basar en una condición. Al ser una declaración DML, es parte de una transacción.
31. What among the following is true about the DELETE statement?
- La declaración DELETE debe ir acompañada de la cláusula WHERE
- No es obligatorio escribir una cláusula WHERE con la declaración DELETE
- DELETE puede eliminar datos de varias tablas a la vez
- Ninguna de las anteriores
Answer: B. El predicado de la cláusula WHERE es opcional en la instrucción DELETE. Si se omite la cláusula WHERE, se eliminarán todas las filas de la tabla.
32.What among the following happens when we issue a DELETE statement on a table? (Choose the most appropriate answer)
- Aparece un mensaje preguntando al usuario si está seguro de eliminar las filas solicitadas
- Las filas que obedecen la condición dada en la declaración DELETE se eliminan inmediatamente
- Las filas solicitadas se eliminan inmediatamente sin ningún aviso.
- Ninguna de las anteriores
Answer: C. Como parte de la transacción activa o nueva, las filas de la tabla se eliminarán.
33.Consider the following data set from the EMPLOYEES table and its structure:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
EMPLOYEE_ID FIRST_NAME JOB_ID
------------------- ------------------ --------
5100 BRUCE
5101 JESSICA SALESMAN
5102 DEBBY SALESMAN
Debe eliminar los datos de la columna JOB_ID en la fila con employee_id 51001. ¿Cuál de las siguientes consultas será correcta?
UPDATE employees SET job_id = NULL WHERE employee_id = 51001;
DELETE job_id FROM employees WHERE employee_id = 51001;
DELETE FROM employees;
- Ninguna de las anteriores
Answer: D. No puede eliminar un valor de columna en particular para una fila en particular con la instrucción DELETE. La fila completa se elimina según las condiciones dadas. Los valores no deseados en una columna se pueden actualizar a NULL. La opción 'A' está cerca pero no es correcta en el contexto de la pregunta.
34. What is the difference between the UPSERT and MERGE statements?
- No hay diferencia
- UPSERT es el último término adoptado para la declaración MERGE, que se ha vuelto obsoleto
- UPSERT puede realizar una operación de eliminación que MERGE no puede
- MERGE hace INSERT, UPDATE y DELETE, UPSERT solo hace UPDATE e INSERT
Answer: D. UPSERT es una declaración obsoleta y MERGE asumió el control con nuevas capacidades.
35. What is the difference between the MERGE command and the commands INSERT, UPDATE and DELETE?
- La instrucción MERGE consume más tiempo que cada operación (INSERT, UPDATE, DELETE) realizada por separado
- MERGE está obsoleto después de Oracle 10g
- MERGE puede realizar las tres operaciones en una mesa mientras INSERT, UPDATE y DELETE realizan una operación a la vez.
- Ninguna de las anteriores.
Answer: C. La instrucción MERGE puede incrustar las tres operaciones en una tabla en una sola instrucción mientras INSERT, UPDATE y DELETE realizan una operación a la vez.
36. Which of the following objects can be the data source in a MERGE statement?
- Una mesa solamente
- Solo una subconsulta
- Una tabla o una subconsulta
- Ambos A o B
Answer: C. MERGE funciona bien con una tabla o una subconsulta.
37. What among the following is a TRUNCATE statement equivalent to? (Choose the most suitable answer)
- A una declaración DELETE
- A una declaración UPDATE
- Una declaración DELETE sin una cláusula WHERE
- Ninguna de las anteriores
Answer: C. TRUNCATE elimina todas las filas en un comando.
38.Which of the following situations indicate that a DML operation has taken place?
- Cuando se agregan nuevas filas a una tabla
- Cuando se combinan dos consultas
- Cuando una tabla está truncada
- Ninguna de las anteriores
Answer: A. Cuando las filas existentes en una tabla se insertan, modifican o eliminan de una tabla, se hace a través de una declaración DML.
39.Which of the following best defines a transaction?
- Una transacción consta de declaraciones DDL en el esquema de la base de datos
- Una transacción consiste en COMMIT o ROLLBACK en una sesión de base de datos
- Una transacción consiste en una colección de declaraciones DML o una declaración DDL o DCL o TCL para formar una unidad lógica de trabajo en una sesión de base de datos.
- Una transacción consiste en la recopilación de declaraciones DML y DDL en diferentes sesiones de la base de datos.
Answer: C. Una transacción de base de datos consta de una o más declaraciones DML para constituir un cambio consistente en los datos, o una declaración DDL o un comando DCL (GRANT o REVOKE). Comienza con la primera instrucción DML y termina con un comando DCL o DDL o TCL (COMMIT o ROLLBACK). Tenga en cuenta que los comandos DDL y DCL tienen la función de confirmación automática.
40. What does a collection of DML statements that form a logical unit work known as?
- Propiedad ACID
- UNION
- UNIÓN TODOS
- Transaction
Answer: D.
41.What happens when a DML statement in an active transaction encounters an error on execution?
- Las transacciones completas se revierten
- Los DML en la transacción son mutuamente excluyentes y, por lo tanto, pueden continuar su ejecución.
- Los otros DML en las transacciones se interrumpen y esperan hasta que se resuelva el error.
- Ninguna de las anteriores
Answer: A. Si alguna de las declaraciones DML en una transacción activa encuentra un error, toda la transacción termina en una reversión.
42.What is true about the keyword VALUES in INSERT statements?
- VALUES puede agregar varias filas a la vez durante el INSERT
- VALUES puede agregar solo 100 filas a la vez durante el INSERT
- VALUES es obligatorio para usar si usamos la palabra clave INSERT
- VALUES agrega solo una fila a la vez
Answer: D. La palabra clave VALUES se usa solo cuando los valores de la columna se especifican explícitamente en la instrucción INSERT.
Consider the following statement and the table structure. Answer the questions 43 to 45 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)
INSERT INTO departments (department_id , department_name , manager_id, location_id )
VALUES (100, 'Human Resources', 121, 1000);
43. How many rows will be inserted by the above statement?
- 0
- 2
- 3
- 1
Answer: D. Cuando se utiliza la palabra clave VALUES, se inserta solo una fila a la vez.
44. In which order the values will get inserted with respect to the above INSERT statement?
- Location_id, manager_id, nombre_departamento, id_departamento
- id_departamento, nombre_departamento, id_gerente, id_ubicación
- Department_id, manager_id, department_name, location_id
- id_departamento, nombre_departamento, id_ubicación, id_gerente
Answer: B. Si las columnas se mencionan en la cláusula INSERT, la palabra clave VALUES debe contener valores en el mismo orden
45. Suppose the above given statement is modified as below:
INSERT INTO departments VALUES (100, 'Human Resources', 121, 1000);
¿Cuál será el resultado de esta modificación? Suponga que la tabla DEPARTMENTS tiene cuatro columnas, a saber, department_id, DEPARTMENT_NAME, MANAGER_ID y LOCATION_ID.
- Insertará valores en todas las columnas de la tabla de departamentos asumiendo que los valores de las columnas se proporcionan en la misma secuencia que la columna de la tabla.
- Lanzará un error ORA porque los nombres de las columnas no se mencionan explícitamente
- Lanzará un error ORA porque la cláusula VALUES se usa incorrectamente en INSERT
- Ninguna de las anteriores
Answer: A. La inclusión de los nombres de las columnas en la instrucción INSERT es opcional siempre que los valores deban cumplir con el recuento y la secuencia de las columnas de la tabla.
46. What will be the outcome of the below INSERT statement? (Consider the table structure)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
INSERT INTO EMPLOYEES (employee_id , hire_date) VALUES (210,"21-JUN-2013");
- Insertará solo el employee_id y la fecha de contratación del empleado, dejando todas las demás columnas en blanco
- Insertará solo el employee_id
- Lanzará un error ORA
- Ninguna de las anteriores
Answer: C. El formato literal de fecha contiene un error. Debe incluirse entre comillas simples y no entre comillas dobles.
47.What will be the outcome of the below INSERT statement? (Consider the given table structure)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
INSERT INTO EMPLOYEES (employee_id , first_name) VALUES (210,"Bryan");
- Insertará solo el employee_id y el nombre de Bryan, dejando todas las demás columnas en blanco
- Insertará solo el nombre
- Lanzará un error ORA
- Ninguna de las anteriores
Answer: C. El formato literal de cadena contiene un error. Debe incluirse entre comillas simples y no entre comillas dobles.
48. Suppose you need to insert the name O'Callaghan as the last name of the employees table. Which of the following queries will give you the required results? (Consider the given table structure)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O'callahan');
INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O"callahan');
INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,'O' 'Callahan');
INSERT INTO EMPLOYEES (employee_id , last_name) VALUES (210,"O'callahan");
Answer: C.
49. What will be the outcome of the below INSERT statement? (Consider the given table structure)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
INSERT INTO EMPLOYEES (employee_id , first_name) VALUES ("210",'Bryan');
- Lanzará un error de valor numérico
- Insertará solo el employee_id y el nombre de Bryan, dejando todas las demás columnas como NULL
- Insertará solo el employee_id
- Ninguna de las anteriores
Answer: A. Los valores numéricos no deben ir entre comillas.
50. What will be the outcome of the below INSERT statement? (Consider the given table structure)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
INSERT INTO departments VALUES (200,'Accounts', NULL, NULL);
- Lanzará un error ORA
- Se ejecutará correctamente pero con valores incorrectos podría insertarse en las columnas
- Se ejecutará con éxito
- Ninguna de las anteriores
Answer: C. Los valores NULL se pueden utilizar en la cláusula VALUES para completar los valores de la columna de forma alternativa.
51. What will be the outcome of the below INSERT statement? (Assume there is a NOT NULL constraint on the department_id column and consider the table structure given)
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)
INSERT INTO departments VALUES (NULL, 'Accounts', NULL);
- Lanzará un error ORA
- Se ejecutará correctamente pero con resultados incorrectos.
- Se ejecutará con éxito pero con resultados correctos.
- Ninguna de las anteriores
Answer: A. Los valores NULL no se pueden insertar en columnas no nulas.
52. What will be the outcome of the below INSERT statement? (Assume there is a NOT NULL constraint on the department_id column and consider the given table structure)
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)
INSERT INTO departments VALUES (200, 34, NULL);
- Se ejecutará correctamente pero con resultados incorrectos.
- Lanzará un error ORA
- Se ejecutará con éxito pero con resultados correctos.
- Ninguna de las anteriores
Answer: B. El tipo de datos del valor no coincide con el tipo de datos de la columna de la tabla.
53. Which of the following commands is used to save the changed data in a table permanently?
- ROLLBACK
- COMMIT
- INSERT
- UPDATE
Answer: B. El comando COMMIT de TCL se utiliza para finalizar la transacción activa actual en una sesión haciendo que todos los cambios de datos pendientes sean permanentes en las tablas.
54. Which of the following commands allows undoing the changed data?
- ROLLBACK
- COMMIT
- INSERT
- UPDATE
Answer: A. El comando TCL ROLLBACK se utiliza para finalizar la transacción activa actual en una sesión descartando todos los cambios de datos pendientes.
55. Which of the following commands allows enabling markers in an active transaction?
- ROLLBACK
- COMMIT
- SAVEPOINT
- Ninguna de las anteriores
Answer: C. SAVEPOINT marca un punto en una transacción que divide la transacción en secciones más pequeñas.
56. Which of the following commands prevents other users from making changes to a table?
- ROLLBACK
- COMMIT
- MESA DE BLOQUEO
- SAVEPOINT
Answer: C.
57. What is true about an INSERT statement which tries to insert values into a virtual column? (Choose the most appropriate answer)
- No puede insertar valores en la columna virtual
- Puede insertar valores
- Lanza un error ORA
- Todas las anteriores
Answer: A. Una columna virtual es una columna que siempre se genera automáticamente en función de la expresión de derivación definida en la especificación de la columna. El usuario no puede insertar explícitamente su valor.
58.Which of the following commands allows the user to insert multiple rows with a single statement?
- INSERT
- INSERTAR TODO
- UNIÓN TODOS
- Ninguna de las anteriores
Answer: B. Las operaciones de inserción masiva se pueden realizar utilizando INSERT ALL.
59. Which of the following is the syntax for inserting rows through a sub-query?
INSERT INTO tablename [{column_name,..}] subquery;
INSERT INTO tablename VALUES [{column_name,..}] subquery;
- Tanto a como B
- Ninguna de las anteriores
Answer: A.
Consider the following exhibit of the EMPLOYEES table and answer the questions 60 to 63 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)
60. Which of the following queries will execute successfully?
UPDATE employees SET salary = salary + 1000 WHERE to_char (hire_date, 'YYYY') > '2006';
UPDATE employees SET salary = salary + 1000 WHERE to_date (hire_date, 'YYYY') > '2006';
UPDATE employees SET salary = salary + 1000 WHERE hire_date > to_date (substr ('01-jan-200',8));
UPDATE employees SET salary = salary + 1000 WHERE hire_date in (to_date ('JUN 01 11', to_date ('JUL 01 11'));
Answer: A.
61.Due to structural reorganization in the organization, you are asked to update department IDs for all the employees to NULL before the final decision is made public. Only those records should be updated which have the JOB_ID as NULL. Which of the following queries will work?
UPDATE employees SET department_id = NULL Where job_id = NULL;
UPDATE employees SET department_id = NULL Where job_id = TO_NUMBER(NULL);
UPDATE employees SET department_id = NULL Where job_id IS NULL;
UPDATE employees SET department_id = TO_NUMBER (' ', 9999) Where job_id = TO_NUMBER(NULL);
Answer: C. Utilice el operador IS NULL para comprobar la nulidad del valor de la columna.
62.You need to add a basic employee data into EMPLOYEES table. The basic data contains the last name as 'Bond' and department ID as 300. Which of the following statements will give the correct results?
INSERT INTO employees (employee_id , last_name, department_id ) (100,'Bond', (select department_id from departments where department_id = 300));
INSERT INTO employees (employee_id , last_name, department_id ) VALUES (100,'Bond', (select department_id from departments where department_id = 300));
INSERT INTO employees (employee_id , last_name, department_id ) VALUES ('100','Bond',300);
- Ninguna de las anteriores
Answer: B, C. Las subconsultas funcionan en declaraciones INSERT siempre que devuelvan un valor escalar de tipo de datos coincidente o compatible con la columna para la que se utilizan.
63. You fire the following query:
DELETE FROM EMPLOYEES;
Suponiendo que no hay transacciones activas en la tabla EMPLOYEES en ninguna sesión, ¿cuál de las siguientes afirmaciones es verdadera?
- Elimina todas las filas y estructura de la tabla.
- Elimina todas las filas que se pueden deshacer.
- Elimina todas las filas de forma permanente
- Ninguna de las anteriores
Answer: B. Al ser una declaración DML, los cambios de datos debidos a la operación DELETE se vuelven permanentes solo después de que se emite COMMIT en la sesión.
64.Consider the structure of the COUNTRY table as shown:
SQL> desc countries
Name Null? Type
----------------------- -------- ----------------
COUNTRY_ID NOT NULL CHAR(2)
COUNTRY_NAME VARCHAR2(40)
REGION_ID NUMBER
Emite las siguientes declaraciones en una sesión.
INSERT INTO COUNTRIES (1, 'Whales')
/
INSERT INTO COUNTRIES (2, 'England')
/
SAVEPOINT A;
UPDATE COUNTRIES
SET country_id= 100 where country_id= 1
/
SAVEPOINT B;
DELETE FROM COUNTRIES where country_id= 2
/
COMMIT
/
DELETE FROM COUNTRIES where country_id= 100
/
¿Qué sucederá cuando se emita un comando ROLLBACK TO SAVEPOINT para la sesión del usuario?
- La reversión genera un error
- Solo se revierten las declaraciones DELETE
- No se revierte ninguna instrucción SQL
- Ninguna de las anteriores
Answer: A, C. Dado que hay dos puntos de guardado: A y B, y el comando ROLLBACK especifica la marca del punto de guardado real, Oracle arroja un error.
65.If a user issues a DML command and exits the SQL Developer abruptly without a COMMIT or ROLLBACK, what will be the outcome? (Assume the session is not auto commit)
- COMMIT automático
- ROLLBACK automático
- Podría ser un COMMIT o ROLLBACK para finalizar la transacción
- Ninguna de las anteriores
Answer: B. Cuando la transacción es interrumpida por una falla del sistema, toda la transacción se revierte automáticamente.
66. Which of the following commands / statements would end a transaction?
- COMMIT
- SELECT
- SAVEPOINT
- CREATE
Answer: A, D. Aparte de los comandos TCL, es decir, COMMIT o ROLLBACK, los comandos DDL y DCL poseen la función de confirmación automática. La transacción activa se confirmará si la declaración DDL se ejecuta en la misma sesión.
67.When does a transaction complete?
- Cuando se ejecuta un ROLLBACK
- Cuando se ejecuta un COMMIT
- Cuando se ejecuta TRUNCATE
- Todas las anteriores
Answer: D. La transacción se completa si se ejecuta un comando TCL, DCL o DDL en la sesión.
68. Examine the given table structures and consider the following query:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
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)
INSERT INTO EMPLOYEES (department_id ) VALUES
(select department_id FROM departments);
¿Cuál será el resultado de la consulta anterior?
- Las columnas de la tabla EMPLEADOS y la tabla de departamentos no coinciden
- La cláusula WHERE es obligatoria para usarse en una subconsulta
- La palabra clave VALUES no se puede utilizar con la cláusula INSERT cuando se utilizan subconsultas
- Ninguna de las anteriores
Answer: C. Uso incorrecto de la palabra clave VALUES. Debe usarse solo cuando tenga datos de columna a mano, que deben insertarse en la tabla.
69.Examine the given table structure and consider the following query:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
UPDATE (select employee_id , job_id from employees)
SET hire_date = '01-JAN-13'
WHERE employee_id = (select employee_id FROM job_history);
¿Cuál de las siguientes afirmaciones es verdadera con respecto a la consulta dada?
- No se ejecutaría ya que no podemos usar dos tablas en una sola declaración de actualización
- No se ejecutaría porque UPDATE no puede usar una subconsulta
- Se ejecutaría con las restricciones en la columna especificada
- No se ejecutaría ya que la subconsulta se usa en la cláusula WHERE
Answer: C.
70.What happens when a transaction is committed?
- Los cambios realizados durante la transacción se guardan para una sesión de usuario en particular
- Se descartan los cambios realizados durante la transacción
- Si la transacción es un DDL, la confirmación no funciona
- Ninguna de las anteriores
Answer: D. La confirmación de una transacción guarda los cambios de datos pendientes de forma permanente en la base de datos.
71. Which of the following reasons will the best one on the usage of string?
- Usar subconsultas
- Errores de sintaxis
- Permisos de acceso
- Violaciones de restricciones
Answer: C, B, D. Referencias a objetos / columnas no existentes, problemas de espacio pueden ser otras razones.
72. What happens when an INSERT statement tries to insert records in an old table?
- Todas las columnas obtendrán valores NULL
- Se crearía una nueva tabla con el mismo nombre automáticamente y los valores se insertarían
- INSERT no puede funcionar y arroja un error ORA
- Ninguna de las anteriores
Answer: C.
73. A user named 'Jonathan Adams' is able to SELECT columns from the EMPLOYEES table but he is unable to insert records into EMPLOYEES. What can be the reason?
- Jonathan está conectado a una base de datos que no admite declaraciones INSERT
- La instrucción INSERT no se puede aplicar en la tabla EMPLOYEES
- Jonathan tiene acceso a SELECT pero no a INSERT INTO la tabla EMPLOYEES
- Ninguna de las anteriores
Answer: C. Los usuarios pueden disfrutar del acceso a la mesa según sus responsabilidades. Uno solo puede tener acceso de lectura en una mesa, mientras que otros pueden disfrutar de acceso de lectura y escritura.
74. Suppose 1 million rows are to be inserted into the AUDIT table. An INSERT transaction runs successfully for the first 1000 rows and an ORA error is thrown 'Constraint violated'. What will happen to the values inserted in the first 1000 rows?
- Permanecerán como están
- Todos serán eliminados
- Todos serán revertidos
- Ninguna de las anteriores
Answer: C. Si alguna de las declaraciones DML durante la transacción encuentra errores, la transacción completa se revertirá.
Examine the table structure and consider the following query and answer the questions 75, 76 and 77 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)
INSERT INTO departments values (15, NULL);
75. What will be the outcome of this statement?
- Insertará una fila con department_id = 15 y todos los demás valores como NULL
- Se ejecutará correctamente pero insertará 0 filas en la tabla.
- Lanzará un error de ORA como el no. de columnas y valores no coinciden
- Ninguna de las anteriores
Answer: C. La tabla DEPARTMENTS contiene cuatro columnas, pero la instrucción INSERT proporciona el valor de dos columnas solo sin mencionar las columnas también. Por lo tanto, se lanza el error ORA.
76. What is true about the above INSERT statement?
- Si las columnas no se mencionan en la instrucción INSERT, los valores se insertan posicionalmente en las columnas
- Es obligatorio mencionar columnas después de la instrucción INSERT.
- Tanto a como B
- Ninguna de las anteriores
Answer: A. Si las columnas no se especifican en la instrucción INSERT, Oracle asigna secuencial y posicionalmente cada valor a la columna de la tabla.
77. With respect to the statement given above, what will happen if the table is altered to add a new column?
- La declaración seguirá funcionando
- La ejecución de la declaración arrojará un error ya que habrá una falta de coincidencia en el no. de columnas y valores
- No habrá cambios y la declaración se ejecutará como antes.
- Ninguna de las anteriores
Answer: B. Dado que las columnas no se especificaron anteriormente, el problema seguirá existiendo. La falta de coincidencia en la asignación de valores de columna arrojaría un error ORA.
Examine the table structure given below and consider the following queries and answer the questions 78 and 79 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)
Query 1:
INSERT INTO employees (employee_id , last_name, hire_date)
VALUES (100, 'ADAMS','21-DEC-12');
Query 2:
INSERT INTO employees (employee_id , last_name, hire_date)
VALUES (100, upper('ADAMS'),to_date('21-DEC-12','DD-MON-YY'));
78. Which of the above two queries is better?
- Ambos son mejores
- Solo la consulta 1 es mejor
- Solo la consulta 2 es mejor
- Ninguna de las consultas es correcta
Answer: C. Query-2 es mejor porque inserta el valor de fecha como una fecha y no como una cadena. Aunque Oracle realizará una conversión implícita del literal de cadena especificado como una fecha, pero no se recomienda.
79. Which of the following queries is equivalent of the query 2 given above?
INSERT INTO employees (employee_id , last_name, hire_date) VALUES (101-1, upper('ADAMS'),to_date('21-DEC-12','DD-MON-YY'));
INSERT INTO employees (employee_id , last_name, hire_date) VALUES (99+1, upper('ADAMS'),to_date('22-DEC-12','DD-MON-YY') +1 );
INSERT INTO employees (employee_id , last_name, hire_date) VALUES (100, upper('ADAMS'),to_date('21-DEC-12','DD-MON-YY') - 1);
INSERT INTO employees (employee_id , last_name, hire_date) VALUES (100, upper('ADAMS'),to_date('28-DEC-12','DD-MON-YY')-7 );
Answer: A, C, D. Se pueden usar operaciones / funciones aritméticas para insertar valores como se muestra arriba.
80. You need to copy the data from one table to another table. Which of the following methods can be used?
- Puede usar el comando COPY
- Puede utilizar el comando INSERT
- Puede utilizar el comando ACTUALIZAR
- Ninguna de las anteriores
Answer: B. Las operaciones de ruta directa INSERT-AS-SELECT (IAS) son el método más utilizado para copiar datos de una tabla a otra.
81.Which of the following statements will copy data from the JOB_HISTORY table to the JOB_HISTORY_ARCHIVE table? (Consider the table structure as given)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
INSERT INTO job_history values (select * from job_history);
INSERT INTO JOB_HISTORY_ARCHIVE values (select * from job_history_archive);
INSERT INTO JOB_HISTORY_ARCHIVE select * from job_history;
- Ninguna de las anteriores
Answer: C. La opción 'C' muestra correctamente el uso del método IAS (INSERT-AS-SELECT).
Examine the given table structure. Consider the following query and answer the questions 82 and 83 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)
INSERT ALL
WHEN job_id = 'SA_REP' then
INTO employees (employee_id , department_id , salary, hire_date)
VALUES (employee_id , 10, salary, hire_date)
WHEN job_id <> 'SA_REP' then
INTO employees (employee_id , department_id , salary, hire_date)
VALUES (employee_id , 20, salary, hire_date)
SELECT employee_id , department_id , job_id, salary, commission_pct , hire_date
FROM employees
WHERE hire_date > sysdate - 30;
82. Interpret the output of the above INSERT statement.
- Arrojó un error
- Insertará los registros de todos los empleados que fueron contratados un mes antes de la fecha del sistema.
- Insertará los registros de todos los empleados que son representantes de ventas en el departamento 10
- Ninguna de las anteriores
Answer: B, C. INSERT ALL puede realizar inserciones condicionales en las tablas de destino.
83. Which employees' data will be inserted in the department 20?
- Representantes de ventas
- Accountants
- Ambos A o B
- Ninguna de las anteriores
Answer: B. Según la declaración INSERT ALL, los detalles de los empleados cuyo job_id no es 'Representante de ventas'.
84. What will be the outcome of the below query? (Consider the table structure as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
INSERT INTO employees (employee_id , salary) VALUES (&employee_id , &salary);
COMMIT;
- Error de sintaxis ya que las variables de sustitución no se pueden utilizar en declaraciones DML
- Se le pedirá al usuario que ingrese la identificación del empleado y el salario, pero las variables de sustitución no pueden insertar datos en la tabla
- Se le pedirá al usuario que ingrese la identificación del empleado y el salario y el registro se crearán con éxito en la tabla EMPLEADOS
- Ninguna de las anteriores
Answer: C. Las variables de sustitución funcionan bien con las declaraciones DML.
85. Evaluate the following SQL statements that are executed in a user session in the specified order:
CREATE SEQUENCE id_seq;
SELECT id_seq.nextval
FROM dual;
INSERT INTO employees (employee_id ,first_name,job_id )
VALUES (ord_seq.CURRVAL, 'Steyn','Trainee');
UPDATE employees
SET employee_id = id_seq.NEXTVAL
WHERE first_name = 'Steyn'
AND job_id ='Trainee';
¿Cuál sería el resultado de las declaraciones anteriores?
- El comando CREATE SEQUENCE arrojaría un error porque no se han especificado los valores mínimo y máximo para la secuencia.
- Todas las declaraciones se ejecutarían correctamente y la columna employee_id contendría el valor 2 para el empleado STEYN.
- El comando CREATE SEQUENCE no se ejecutaría porque no se han especificado el valor inicial de la secuencia y el valor de incremento.
- Todas las declaraciones se ejecutarían correctamente y la columna employee_id tendría el valor 20 para el empleado STEYN porque el valor predeterminado de CACHE es 20.
Answer: B.
86. What is the restriction on the sub-query used in the UPDATE statement?
- La subconsulta debe ser una subconsulta de varias filas
- La subconsulta debe ser una subconsulta de una sola fila
- No hay restricción
- La subconsulta puede ser una subconsulta de una sola fila o de varias filas
Answer: B. La subconsulta no debe devolver varias filas cuando se usa en una instrucción UPDATE
Examine the given table structure and consider the query given below and answer the questions 87 and 88 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)
UPDATE employees
SET salary = (SELECT salary FROM employees WHERE employee_id =7382);
87. What will be the outcome of the above query?
- Lanza un error ORA en ejecución
- Se actualizará el salario de todos los empleados con el mismo salario que el empleado 7382
- El salario de todos los empleados se actualizará a NULO
- Ninguna de las anteriores
Answer: B. Los resultados de la consulta se pueden utilizar para actualizar los valores de columna en una tabla.
88. Suppose if the employee 7382 doesn't exist in the EMPLOYEES table. What will be the outcome of the query?
- Lanza un error ORA en la ejecución porque los resultados de la consulta no se pueden actualizar a las columnas
- El salario de todos los empleados se actualizará a NULO
- Se generará la excepción de ORA 'NO_DATA_FOUND' porque el empleado 7382 no existe
- Ninguna de las anteriores
Answer: B. Las sentencias UPDATE no generan ninguna excepción a excepción de los errores sintácticos.
Examine the given table structure and consider the query given below and answer the questions 89 and 90 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)
UPDATE employees
set salary = (select salary from employees where last_name = 'Adams');
89. What will be the outcome of the query?
- Se ejecuta con éxito
- Todas las filas de la tabla tienen el mismo salario.
- Podría arrojar un error ORA 'TOO_MANY_ROWS' al ejecutarse
- Ninguna de las anteriores
Answer: C. La subconsulta puede devolver más de una fila provocando un error.
90. What changes in the above query will make sure there are no errors caused?
- Utilice una función de una sola fila como MAX, MIN o AVG para reducir los resultados de varias filas en un resultado escalar
- Agregar una restricción de clave primaria en la columna SALARIO
- No se requiere cambio
- Ninguna de las anteriores
Answer: A.
Examine the given table structure and consider the following query and answer the questions 91 and 92 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)
UPDATE employees
SET salary = (select max (salary) from employees where last_name = 'Adams');
91. What will be the outcome of the query given above?
- Actualizará los salarios de todos los empleados igual al salario del empleado llamado Adam
- Actualizará los salarios de todos los empleados igual al salario promedio de todos con apellido como 'Adam'
- Actualizará 0 filas
- Actualizará solo una fila
Answer: B. Las funciones aritméticas MAX o MIN se pueden usar con subconsultas para obtener valores escalares y evitar errores.
92. Assume that the sub-query above is replaced with the following:
SELECT distinct salary from employees where last_name = 'Adam';
¿Cuál será el resultado de la consulta principal dada anteriormente?
- Se ejecutará con éxito dando resultados incorrectos.
- Se ejecutará con éxito dando resultados correctos.
- Lanzará un error ORA
- Ninguna de las anteriores
Answer: C. da un error porque como hay muchos con el apellido 'Adam' habrá muchos sueldos distintos.
Examine the given table structure and consider the following query and answer the questions 93 and 94 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)
UPDATE employees
SET salary = 50000;
WHERE job_id in (select job_id from job_history where department_id = 10);
93. What will the above statement do? (Choose the most appropriate answer)
- Actualizará todos los salarios de todos los empleados como 50000
- Actualizará todos los salarios de todos los empleados que están en el departamento 10
- Actualizará los salarios de todos los empleados que tengan uno de los ID de puesto similares a los del departamento 10
- Ninguna de las anteriores
Answer: C.
94. What will happen if the WHERE clause given above is replaced with the following?
WHERE job_id = (select job_id from job_history where department_id = 10);
- Se ejecutará correctamente con resultados incorrectos.
- Se ejecutará con éxito con resultados correctos.
- Lanzará un error ORA
- Ninguna de las anteriores
Answer: C. El signo igual provocará el error.
Examine the given table structure and consider the following statement. Answer the questions 95 to 97 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)
DELETE FROM employees where last_name = 'A%';
COMMIT;
95. What will be the outcome of the query given above?
- Se ejecuta correctamente pero no se eliminan filas
- Se eliminarán todos los empleados cuyo apellido comience con "A"
- Error de ORA porque la instrucción DELETE no puede tener el predicado WHERE
- Se eliminarán todas las filas de la tabla de empleados
Answer: A. La sentencia DELETE puede tener un predicado de cláusula WHERE. Según las condiciones, los registros se eliminarán de la tabla.
96. Consider the following statement:
DELETE FROM employees where employee_id IS NULL and job_id = NULL;
COMMIT;
Suponiendo que hay una restricción NOT NULL en la columna employee_id, ¿cuál será el resultado de la consulta anterior?
- Generará un error ORA debido a predicados WHERE no válidos
- Se ejecutará correctamente y no se eliminarán filas.
- Generará un error de ORA porque varios predicados no pueden funcionar en declaraciones DELETE
- Ninguna de las anteriores
Answer: B. Se pueden aplicar múltiples predicados a las sentencias DML UPDATE y DELETE.
97. Consider the following query:
DELETE FROM employees where department_id = &deptID;
COMMIT;
¿Qué pasará cuando se ejecute la declaración anterior?
- Generará un error porque las declaraciones DML no pueden usar variables de sustitución
- Solicitará que se elimine el ID de departamento del usuario y eliminará el registro con el ID de departamento dado
- Solicitará el ID del departamento, pero la transacción no se puede confirmar.
- Ninguna de las anteriores
Answer: B. Las variables de sustitución se pueden utilizar con declaraciones DML.
98. All parts of a transaction should complete or none of them. Which property of ACID rule complies with the given statement?
- Atomicity
- Consistency
- Isolation
- Durability
Answer: A. ACID se refiere a las propiedades básicas de una transacción de base de datos: atomicidad, consistencia, aislamiento y durabilidad. La atomicidad implica que la secuencia completa de acciones debe completarse o abortarse. La coherencia implica que la transacción lleva los recursos de un estado coherente a otro. El aislamiento implica que el efecto de una transacción no es visible para otras transacciones hasta que la transacción se confirma. La durabilidad implica que los cambios realizados por la transacción comprometida son permanentes y deben sobrevivir a la falla del sistema.
99. What does the principle of Durability in the ACID property state?
- Afirma que una base de datos puede perder transacciones completadas
- Establece que una transacción no se puede completar
- Establece que una vez que se completa una transacción, debe ser imposible que la base de datos la pierda.
- Ninguna de las anteriores
Answer: C.
100. An incomplete transaction should be invisible to all the other users. Which of the properties of the ACID state this?
- Isolation
- Consistency
- Atomicity
- Durability
Answer: A. "Yo" significa Aislamiento.
101. What does the principle of consistency states?
- Establece que los resultados de una consulta deben ser consistentes con el estado de la base de datos en el momento en que se inició la consulta.
- Establece que una transacción incompleta debe ser invisible para todos los demás usuarios.
- Establece que una vez que se completa una transacción, debe ser imposible que la base de datos la pierda
- Ninguna de las anteriores
Answer: A. la "C" en la propiedad ACID significa Consistencia
102. What among the following best describes a Transaction?
- INSERT para COMMIT / ROLLBACK
- ACTUALIZAR a COMMIT / ROLLBACK
- BORRAR para COMPROMISO / ROLLBACK
- INSERT / UPDATE / DELETE to COMMIT / ROLLBACK
Answer: D.
103. A user named "Jonathan" inserts data in the table EMPLOYEES. When will the other users be able to see the new data?
- Cuando Jonathan otorga permiso de acceso a los usuarios
- Cuando Jonathan ejecuta una instrucción ROLLBACK en la sesión
- Cuando Jonathan ejecuta una declaración COMMIT en la misma sesión
- Cuando Jonathan abre una nueva sesión y emite un COMMIT
Answer: C. La transacción activa debe confirmarse en la misma sesión.
104. What can be said about the nesting of transactions?
- Es posible un máximo de 2 niveles de anidación
- Es posible un máximo de 255 niveles de anidamiento
- El anidamiento de una transacción es imposible
- Solo es posible 1 nivel de anidamiento
Answer: C.
105. Which of the following reasons will terminate a transaction?
- Una declaración DDL
- Salir de un cliente
- Fallos del sistema
- Todas las anteriores
Answer: D. DDL se confirma automáticamente y finalizará la transacción activa en curso.