Está en la página 1de 254

Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
Oracle Database:
8 4 4 eConceptos
n t
a r d0 Studde SQL I
Fundamentales
( r ich this
i r ez use
R to II • Guía del Alumno
am se Volumen
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

D64258CS10
Edición 1.0
Enero de 2010
D73591
Autores Copyright © 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Salome Clement Renuncia


Brian Pottle Este documento contiene información propiedad de Oracle Corporation y se
Puja Singh encuentra protegido por las leyes de copyright, así como por otras leyes de
propiedad intelectual. El usuario podrá realizar copias o imprimir este documento
Colaboradores y para su uso exclusivo en los cursos de formación de Oracle. Este documento no
podrá ser modificado ni alterado en modo alguno. Salvo que la legislación de
Revisores Técnicos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

copyright lo considere un uso legítimo, no podrá utilizar, compartir, descargar, cargar,


copiar, imprimir, mostrar, representar, reproducir, publicar, conceder licencias, enviar,
Anjulaponni Azhagulekshmi transmitir ni distribuir este documento total ni parcialmente sin autorización expresa
Clair Bennett por parte de Oracle.
Zarko Cesljas
Yanti Chang La información contenida en este documento está sujeta a cambio sin previo aviso.
Si detecta cualquier problema en el documento, le agradeceremos que nos lo
Gerlinde Frenzen comunique por escrito a: Oracle University, 500 Oracle Parkway, Redwood Shores,
Steve Friedberg California 94065 USA. Oracle Corporation no garantiza que este documento esté
Joel Goodman exento de errores.
Nancy Greenberg
Aviso sobre Restricción de Derechos
s a
) ha
Pedro Neves
Manish Pawar Si esta documentación se entrega al Gobierno de los EE. UU. o a cualquier entidad
Surya Rekha
c om
que la utilice en nombre del Gobierno de los EE. UU., se aplicará la siguiente
l ฺ
Helen Robertson
Lauran Serhal
disposición:

t m ai eฺ
Hilda Simon
@ ho Guid
U.S. GOVERNMENT RIGHTS
The U.S. Government’s rights to use, modify, reproduce, release, perform, display, or
Tulika Srivastava
8 4 4 ent
disclose these training materials are restricted by the terms of the applicable Oracle

d0 Stud
license agreement and/or the applicable U.S. Government contract.
Redactor a r
ich this
Aviso de Marca Registrada
Amitha Narayan ( r
z use Oracle es una marca comercial registrada de Oracle Corporation y/o sus filiales.
i r e Todos los demás nombres pueden ser marcas comerciales de sus respectivos
Diseñador Gráfico
R am se to propietarios.
Rajiv Chandrabhanu
o p ez licen
Publicador
r d o L rable
ica nsfe
Jobi Varghese
R
c s on n-tra
i no
Ed
Contenido
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

I Introducción
Objetivos I-2
Agenda I-3
Objetivos del Curso I-4
Agenda I-5
Apéndices Utilizados en el Curso I-7
s a
) ha
Agenda I-8

l ฺ c om
Oracle Database 11g: Áreas de Atención I-9
Oracle Database 11g I-10
t m ai eฺ
@ ho Guid
Oracle Fusion Middleware I-12
Oracle Enterprise Manager Grid Control I-13
8 4 4 ent
Oracle BI Publisher I-14
a
Agenda I-15r d0 Stud
( r ich this
Sistema de Gestión de Bases de Datos Relacionales y Relacionales de Objetos I-16
i r ez use
Almacenamiento de Datos en Diferentes Medios Físicos I-17
R am se to
Concepto de Base de Datos Relacional I-18

o p ez licen Definición de una Base de Datos Relacional I-19

r d o L rable Modelos de Datos I-20

R ica nsfe Modelo de Relación de Entidades I-21

c s on n-tra Convenciones de Modelado de Relación de Entidades I-23


i no Relación de Varias Tablas I-25
Ed Terminología de Bases de Datos Relacionales I-27
Agenda I-29
Uso de SQL para Consultar Base de Datos I-30
Sentencias SQL I-31
Entornos de Desarrollo para SQL I-32
Agenda I-33
Esquema Human Resources(HR) I-34
Tablas Utilizadas en el Curso I-35
Agenda I-36
Documentación de Oracle Database I-37
Recursos Adicionales I-38
Resumen I-39
Práctica I: Visión General I-40

iii
1 Recuperación de Datos Mediante la Sentencia SQL SELECT
Objetivos 1-2
Agenda 1-3
Capacidades de las Sentencias SQL SELECT 1-4
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Sentencia SELECT Básica 1-5


Selección de Todas las Columnas 1-6
Selección de Columnas Concretas 1-7
Escritura de Sentencias SQL 1-8
Valores por Defecto de Cabeceras de Columna 1-9
Agenda 1-10
Expresiones Aritméticas 1-11
s a
) ha
Uso de Operadores Aritméticos 1-12
Prioridad de Operadores 1-13
l ฺ c om
t m ai eฺ
Definición de Valor Nulo 1-14
Valores Nulos en Expresiones Aritméticas 1-15
Agenda 1-16 @ ho Guid
8 4 4 ent
Definición de Alias de Columna 1-17
a r d0 Stud
Uso de Alias de Columna 1-18
( r ich this
Agenda 1-19
i r ez use
Operador de Concatenación 1-20
R am se to
Cadenas de Caracteres Literales 1-21

o p ez licen Uso de Cadenas de Caracteres Literales 1-22

r d o L rable Operador de Comillas (q) Alternativo 1-23

R ica nsfe Filas Duplicadas 1-24

c s on n-tra Agenda 1-25


i no Visualización de la Estructura de la Tabla 1-26
Ed Uso del Comando DESCRIBE 1-27
Prueba 1-28
Resumen 1-29
Práctica 1: Visión General 1-30

2 Restricción y Ordenación de Datos


Objetivos 2-2
Agenda 2-3
Limitación de Filas con una Selección 2-4
Limitación de las Filas Seleccionadas 2-5
Uso de la Cláusula WHERE 2-6
Fechas y Cadenas de Caracteres 2-7
Operadores de Comparación 2-8
Uso de Operadores de Comparación 2-9

iv
Uso de Condiciones de Rango mediante el Operador BETWEEN 2-10
Condición de Miembro mediante el Operador IN 2-11
Coincidencia de Patrones mediante el Operador LIKE 2-12
Combinación de Caracteres Comodín 2-13
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Uso de las Condiciones NULL 2-14


Definición de Condiciones mediante los Operadores Lógicos 2-15
Uso del Operador AND 2-16
Uso del Operador OR 2-17
Uso del Operador NOT 2-18
Agenda 2-19
Reglas de Prioridad 2-20
s a
Agenda 2-22
) ha
Uso de la Cláusula ORDER BY 2-23
l ฺ c om
Ordenación 2-24
t m ai eฺ
Agenda 2-26
@ ho Guid
8 4 4 ent
Variables de Sustitución 2-27

a r d0 Stud
Uso de la Variable de Sustitución de Un Solo Ampersand 2-29

( r ich this
Valores de Fecha y Carácter con Variables de Sustitución 2-31
Especificación de Nombres de Columna, Expresiones y Texto 2-32
i r ez use
Uso de Variables de Sustitución de Dos Ampersands 2-33
R am se to
Agenda 2-34
o p ez licen
Uso del Comando DEFINE 2-35
Uso d
L le
deloComandobVERIFY 2-36
a r fe r a
R icPruebans2-37
s - tra 2-38
on nResumen
i c no Práctica 2: Visión General 2-39
Ed
3 Uso de Funciones de Una Sola Fila para Personalizar la Salida
Objetivos 3-2
Agenda 3-3
Funciones SQL 3-4
Dos Tipos de Funciones SQL 3-5
Funciones de Una Sola Fila 3-6
Agenda 3-8
Funciones de Carácter 3-9
Funciones de Conversión de Caracteres 3-11
Using Case-Conversion Functions 3-12
Uso de Funciones de Conversión de Caracteres 3-12
Funciones de Manipulación de Caracteres 3-13
Uso de las Funciones de Manipulación de Caracteres 3-14

v
Agenda 3-15
Funciones Numéricas 3-16
Uso de la Función ROUND 3-17
Uso de la Función TRUNC 3-18
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Uso de la Función MOD 3-19


Agenda 3-20
Trabajo con Fechas 3-21
Formato de Fecha RR 3-22
Uso de la Función SYSDATE 3-24
Operadores Aritméticos con Fechas 3-25
Uso de Operadores Aritméticos con Fechas 3-26 a
s
) ha
Agenda 3-27
Funciones de Manipulación de Fecha 3-28
l ฺ c om
Uso de las Funciones de Fecha 3-29
t m ai eฺ
Prueba 3-31 @ ho Guid
Uso de las Funciones ROUND y TRUNC con Fechas 3-30

8 4 4 ent
Resumen 3-32
a r d0 Stud
ich this
Práctica 3: Visión General 3-33
( r
z useCondicionales
4 Uso de Funciones de Conversión iyre Expresiones
Objetivos 4-2 R am se to
Agenda 4-3
o p ez licen
Funciones de o L ble4-4
Conversión
r d
a Implícita ra Tipo de Dato 4-5
edel
i c
Conversión
R raExplícita s f
n del Tipo de Dato 4-7
s o n
Conversión
- t
d ic Agenda
n on 4-10
E Uso de la Función TO_CHAR con Fechas 4-11
Elementos del Modelo de Formato de Fecha 4-12
Uso de la Función TO_CHAR con Fechas 4-16
Uso de la Función TO_CHAR con Números 4-17
Uso de Funciones TO_NUMBER y TO_DATE 4-20
Uso de las Funciones TO_CHAR y TO_DATE con el Formato de Fecha RR 4-22
Agenda 4-23
Funciones de Anidación 4-24
Funciones de Anidación: Ejemplo 1 4-25
Funciones de Anidación: Ejemplo 2 4-26
Agenda 4-27
Funciones Generales 4-28
Función NVL 4-29
Uso de la Función NVL 4-30

vi
Uso de la Función NVL2 4-31
Uso de la Función NULLIF 4-32
Uso de la Función COALESCE 4-33
Agenda 4-36
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Expresiones Condicionales 4-37


Expresión CASE 4-38
Uso de la Expresión CASE 4-39
Función DECODE 4-40
Uso de la Función DECODE 4-41
Prueba 4-43
Resumen 4-44
s a
Práctica 4: Visión General 4-45
) ha
l ฺ c om
5 Informes de Datos Agregados con Funciones de Grupo
t m ai eฺ
Objetivos 5-2
@ ho Guid
Agenda 5-3
8 4 4 ent
¿Qué Son las Funciones de Grupo? 5-4
a r d0 Stud
Tipos de Funciones de Grupo 5-5
Funciones de Grupo: Sintaxis 5-6 (r
ich this
Uso de las Funciones AVG y iSUM r ez5-7 use
m e to
ay MAX
Uso de Funciones MIN
z R n s5-8
e
op COUNT
Uso de la Función e
lic 5-9
L
deola Palabra l e
Uso d
a r f e r abClave DISTINCT 5-10
c
Ri Funciones
n s de Grupo y Valores Nulos 5-11
n -t r a
i c so onAgenda 5-12

Ed n Creación de Grupos de Datos 5-13


Creación de Grupos de Datos: Sintaxis de la Cláusula GROUP BY 5-14
Uso de la Cláusula GROUP BY 5-15
Agrupación de Más de Una Columna 5-17
Uso de la Cláusula GROUP BY en Varias Columnas 5-18
Consultas No Válidas Realizadas con las Funciones de Grupo 5-19
Restricción de Resultados de Grupo 5-21
Restricción de Resultados de Grupo con la Cláusula HAVING 5-22
Uso de la Cláusula HAVING 5-23
Agenda 5-25
Anidamiento de Funciones de Grupo 5-26
Prueba 5-27
Resumen 5-28
Práctica 5: Visión General 5-29

vii
6 Visualización de Datos de Varias Tablas Utilizando Uniones
Objetivos 6-2
Agenda 6-3
Obtención de Datos de Varias Tablas 6-4
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Tipos de Uniones 6-5


Unión de Tablas mediante la Sintaxis SQL:1999 6-6
Cualificación de Nombres de Columna Ambiguos 6-7
Agenda 6-8
Creación de Uniones Naturales 6-9
Recuperación de Registros con Uniones Naturales 6-10
Creación de Uniones con la Cláusula USING 6-11
Unión de Nombres de Columna 6-12 s a
Recuperación de Registros con la Cláusula USING 6-13 ) ha
l ฺ c om
Creación de Uniones con la Cláusula ON 6-15 t m ai eฺ
Uso de Alias de Tabla con la Cláusula USING 6-14

Recuperación de Registros con la Cláusula ON 6-16 @ ho Guid


8 4 4 ent
a r d0 Stud
Creación de Uniones en 3 Direcciones con la Cláusula ON 6-17

ich this
Aplicación de Condiciones Adicionales a una Unión 6-18
Agenda 6-19 ( r
ez use
Unión de una Tabla consigo Misma ir6-20
R am ON
Autouniones que Utilizan la Cláusula e to
6-21
p e z cens
e li
Agenda 6-22
o Lo b6-23
Uniones no igualitarias l
c ard desRegistros
Recuperación
i f era con Uniones no Igualitarias 6-24
n R 6-25
Agenda r an
s o - t
d n on de Registros sin Coincidencia Directa con las uniones OUTER 6-26
ic Devolución
E Uniones INNER frente a Uniones OUTER 6-27
LEFT OUTER JOIN 6-28
RIGHT OUTER JOIN 6-29
FULL OUTER JOIN 6-30
Agenda 6-31
Productos Cartesianos 6-32
Generación de un Producto Cartesiano 6-33
Creación de Uniones Cruzadas 6-34
Prueba 6-35
Resumen 6-36
Práctica 6: Visión General 6-37

viii
7 Uso de Subconsultas para Solucionar Consultas
Objetivos 7-2
Agenda 7-3
Uso de una Subconsulta para Solucionar Problemas 7-4
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Sintaxis de la Subconsulta 7-5


Uso de Subconsultas 7-6
Instrucciones para el Uso de Subconsultas 7-7
Tipos de Subconsultas 7-8
Agenda 7-9
Subconsultas de Una Sola Fila 7-10
Ejecución de Subconsultas de una Sola Fila 7-11
Uso de Funciones de Grupo en una Subconsulta 7-12 s a
Cláusula HAVING con Subconsultas 7-13 ) ha
l ฺ c
¿Qué Parte de esta Sentencia Es Incorrecta? 7-14 om
t m ai eฺ
La Consulta Interna No Devuelve Ningún Resultado 7-15
Agenda 7-16 @ ho Guid
8 4 4 ent
Subconsultas de Varias Filas 7-17
a r d0 Stud
Uso del Operador ANY en Subconsultas de Varias Filas 7-18
h Varias
icde s 7-19
Uso del Operador ALL en Subconsultas
z ( r e thiFilas
Uso del Operador EXISTS 7-20
m ire to us
Agenda 7-21
z Ra nse
Valores Nulosp
o euna Subconsulta
en
l i c e 7-22
L ble
Pruebao 7-24
r d
a sf7-25
Resumen era
i c
R Práctica
o n - t r an7: Visión General 7-26
s
ic non
Ed 8 Uso de los Operadores de Definición
Objetivos 8-2
Agenda 8-3
Operadores de Definición 8-4
Instrucciones de los Operadores de Definición 8-5
Servidor de Oracle y Operadores de Definición 8-6
Agenda 8-7
Tablas Utilizadas en esta Lección 8-8
Agenda 8-12
Operador UNION 8-13
Uso del Operador UNION 8-14
Operador UNION ALL 8-16
Uso del Operador UNION ALL 8-17
Agenda 8-18

ix
Operador INTERSECT 8-19
Uso del Operador INTERSECT 8-20
Agenda 8-21
Operador MINUS 8-22
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Uso del Operador MINUS 8-23


Agenda 8-24
Coincidencia de las Sentencias SELECT 8-25
Coincidencia de las Sentencias SELECT: Ejemplo 8-26
Agenda 8-27
Uso de la Cláusula ORDER BY en Operaciones de Definición 8-28
Prueba 8-29
s a
Resumen 8-30
) ha
Práctica 8: Visión General 8-31
l ฺ c om
t m ai eฺ
9 Manipulación de Datos
@ ho Guid
Objetivos 9-2
8 4 4 ent
Agenda 9-3
a r d0 Stud
Lenguaje de Manipulación de Datos 9-4
Adición de una Nueva Fila a una Tabla 9-5(r
ich this
ez use
Sintaxis de las Sentencias INSERT ir9-6
Inserción de Filas 9-7 R am se to
o ez lNulos
Inserción de Filas conpValores i c en 9-8
r d o L rEspeciales
Inserción de Valores
a ble 9-9
R icade Valores
Inserción
n s fede Fecha y Hora Específicos 9-10
s n
oCreación
n - traun Script 9-11
de
c
i Copia node Filas de Otra Tabla 9-12
Ed Agenda 9-13
Cambio de Datos en la Tabla 9-14
Sintaxis de Sentencias UPDATE 9-15
Actualización de Filas en una Tabla 9-16
Actualización de Dos Columnas con una Subconsulta 9-17
Actualización de Filas Basada en Otra Tabla 9-18
Agenda 9-19
Eliminación de Filas de Tablas 9-20
Sentencia DELETE 9-21
Supresión de Filas de Tablas 9-22
Supresión de Filas Basada en Otra Tabla 9-23
Sentencia TRUNCATE 9-24
Agenda 9-25
Transacciones de Base de Datos 9-26

x
Transacciones de la Base de Datos: Inicio y Fin 9-27
Ventajas de las Sentencias COMMIT y ROLLBACK 9-28
Sentencias de Control de Transacciones Explícitas 9-29
Rollback de los Cambios de un Marcador 9-30
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Procesamiento de Transacciones Implícitas 9-31


Estado de los Datos antes de COMMIT o ROLLBACK 9-33
Estado de los Datos después de COMMIT 9-34
Confirmación de Datos 9-35
Estado de los Datos después de ROLLBACK 9-36
Estado de los Datos después de ROLLBACK: Ejemplo 9-37
Rollback a Nivel de Sentencias 9-38 a
s
) ha
Agenda 9-39
Consistencia de Lectura 9-40
l ฺ c om
t m ai eฺ
Implementación de Consistencia de Lectura 9-41
Agenda 9-42
@ ho Guid
Cláusula FOR UPDATE en una Sentencia SELECT 9-43
8 4 4 ent
Cláusula FOR UPDATE: Ejemplos 9-44
a r d0 Stud
Prueba 9-46
Resumen 9-47 ( r ich this
i
Práctica 9: Visión General 9-48 r ez use
R am se to
p
10 Uso de Sentencias
o ez DDLl i c en Crear y Gestionar Tablas
para
o L10-2
Objetivos
r d a b le
a s10-3
icAgenda f er
R
n Objetos r ande Base de Datos 10-4
s o - t
d ic nonReglas de Nomenclatura 10-5
E Agenda 10-7
Sentencia CREATE TABLE 10-8
Referencia a Tablas de Otro Usuario 10-9
Opción DEFAULT 10-10
Creación de Tablas 10-11
Agenda 10-12
Tipos de Dato 10-13
Tipos de Dato de Fecha y Hora 10-15
Agenda 10-16
Inclusión de Restricciones 10-17
Instrucciones de Restricción 10-18
Definición de Restricciones 10-19
Restricción NOT NULL 10-21
Restricción UNIQUE 10-22

xi
Restricción PRIMARY KEY 10-24
Restricción FOREIGN KEY: Palabras Clave 10-27
Restricción CHECK 10-28
Sentencia CREATE TABLE: Ejemplo 10-29
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Violación de Restricciones 10-30


Agenda 10-32
Creación de una Tabla mediante una Subconsulta 10-33
Agenda 10-35
Sentencia ALTER TABLE 10-36
Tablas de Sólo Lectura 10-37
Agenda 10-38 a
s
) ha
Borrado de una Tabla 10-39
Prueba 10-40
l ฺ c om
Resumen 10-41
t m ai eฺ
Práctica 10: Visión General 10-42
@ ho Guid
8 4 4 ent
11 Creación de Otros Objetos de Esquema
Objetivos 11-2 a r d0 Stud
Agenda 11-3 ( r ich this
Objetos de Base de Datos 11-4 ire
z use
¿Qué es una Vista? 11-5 Ra
m e to
Ventajas de las Vistaspe
z cens
11-6
Vistas Simplesoy L
o le 11-7
Complejas
li
Creación ade ab
rdVistasfe11-8
r
c
Ri randesDatos de una Vista 11-11
n
Recuperación
-t de Vistas 11-12
soModificación
i c o n
Ed n
Creación de Vistas Complejas 11-13
Reglas para Realizar Operaciones DML en una Vista 11-14
Uso de la Cláusula WITH CHECK OPTION 11-17
Denegación de Operaciones DML 11-18
Eliminación de Vistas 11-20
Práctica 11: Visión General de la Parte 1 11-21
Agenda 11-22
Secuencias 11-23
Sentencia CREATE SEQUENCE: Sintaxis 11-25
Creación de Secuencias 11-26
Pseudocolumnas NEXTVAL y CURRVAL 11-27
Uso de una Secuencia 11-29
Almacenamiento en Caché de los Valores de Secuencia 11-30
Modificación de una Secuencia 11-31

xii
Instrucciones para Modificar una Secuencia 11-32
Agenda 11-33
Índices 11-34
¿Cómo se Crean los Índices? 11-36
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Creación de Índices 11-37


Instrucciones de Creación de Índices 11-38
Eliminación de Índices 11-39
Agenda 11-40
Sinónimos 11-41
Creación de un Sinónimo para un Objeto 11-42
Creación y Eliminación de Sinónimos 11-43
Prueba 11-44 s a
Resumen 11-45 ) ha
l ฺ
Práctica 11: Visión General de la Parte 2 11-46 c om
t m ai eฺ
Apéndice A: Prácticas y Soluciones
@ ho Guid
8 4 4 ent
Apéndice AP: Prácticas y Soluciones adicionales
a r d0 Stud
( r ich this
Apéndice B: Descripciones de las
i r ezTablasuse
R am se to
Apéndice C: Uso de
o p ezSQL lDeveloper
i c en
Objetivos LC-2
r
¿Qué d o raSQL
es Oracle bleDeveloper? C-3
a sfe
icEspecificaciones
n R r a n de SQL Developer C-4
o t
- de SQL Developer 1.5 C-5
d ics nonInterfaz
E Creación de una Conexión a la Base Datos C-7
Examen de Objetos de Bases de Datos C-10
Visualización de la Estructura de la Tabla C-11
Examen de Archivos C-12
Creación de un Objeto de Esquema C-13
Creación de una Nueva Tabla: Ejemplo C-14
Uso de la Hoja de Trabajo de SQL C-15
Ejecución de Sentencias SQL C-18
Guardado de Scripts SQL C-19
Ejecución de Archivos de Script Guardados: Método 1 C-20
Ejecución de Archivos de Script Guardados: Método 2 C-22
Formato del Código SQL C-23
Uso de Fragmentos C-24
Uso de Fragmentos: Ejemplo C-25
Depuración de Procedimientos y Funciones C-26

xiii
Informes de Bases de Datos C-27
Creación de un Informe Definido por el Usuario C-28
Motores de Búsqueda y Herramientas Externas C-29
Definición de Preferencias C-30
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Restablecimiento del Diseño de SQL Developer C-31


Resumen C-32

Apéndice D: Uso de SQL*Plus


Objetivos D-2
Interacción de SQL y SQL*Plus D-3
Sentencias SQL frente a Comandos SQL*Plus D-4
Visión General de SQL*Plus D-5 s a
Conexión a SQL*Plus D-6 ) ha
l ฺ c om
Visualización de la Estructura de la Tabla D-7
t
Comandos de Edición SQL*Plus D-9m ai eฺ
Uso de LIST, n y APPEND D-11
@ ho Guid
Uso del Comando CHANGE D-12 8 4 4 ent
Comandos de Archivos SQL*Plus D-13 a r d0 Stud
Using the SAVE, START Commands D-14 (ric
h his
Comando SERVEROUTPUT D-15 ire
z use t
Uso del Comando SQL*PlusR am D-16
SPOOL e to
p e
Uso del Comando AUTOTRACE
z cD-17e ns
Resumen D-18 o Lo ble li
i c ard sfera
n R E: Uso
Apéndice r ande JDeveloper
s o - t
d n on E-2
ic Objetivos
E Oracle JDeveloper E-3
Database Navigator E-4
Creación de Conexión E-5
Examen de Objetos de Bases de Datos E-6
Ejecución de Sentencias SQL E-7
Creación de Unidades de Programa E-8
Compilación E-9
Ejecución de una Unidad de Programa E-10
Borrado de una Unidad de Programa E-11
Ventana Structure E-12
Ventana del Editor E-13
Navegador de Aplicaciones E-14
Despliegue de Procedimientos Java Almacenados E-15
Publicación de Java en PL/SQL E-16

xiv
¿Cómo Puedo Obtener más Información sobre JDeveloper 11g? E-17
Resumen E-18

Apéndice F: Sintaxis de Unión en Oracle


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Objetivos F-2
Obtención de Datos de Varias Tablas F-3
Productos Cartesianos F-4
Generación de un Producto Cartesiano F-5
Tipos de Uniones Propiedad de Oracle F-6
Unión de Tablas mediante la Sintaxis de Oracle F-7
Cualificación de Nombres de Columna Ambiguos F-8
Uniones igualitarias F-9 s a
Recuperación de Registros con Uniones Igualitarias F-10 ) ha
l ฺ c om
Recuperación de Registros con Uniones Igualitarias: Ejemplo F-11
t m ai eฺ
Condiciones de Búsqueda Adicionales Mediante el Operador AND F-12
ho Guid
Unión de Más de Dos Tablas F-13
@
8 4 4 ent
Uniones no Igualitarias F-14
r d0 Stud
Recuperación de Registros con Uniones no Igualitarias F-15
a
r ich this
Devolución de Registros sin Coincidencia Directa con las Uniones Externas F-16
(
i r ez use
Uniones Externas: Sintaxis F-17

R am se to
Uso de Uniones Externas F-18

o p ez licen Unión Externa: Otro Ejemplo F-19

r d o L rable Unión de una Tabla consigo Misma F-20


Autounión: Ejemplo F-21
R ica nsfe Resumen F-22
c s on n-tra Práctica F: Visión General F-23
i no
Ed
Índice

xv
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Apéndice A
Prácticas y Soluciones
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Tabla de Contenido
Prácticas para la Lección I ........................................................................................................ 3
Práctica I-1: Introducción ............................................................................................... 4
Soluciones a la Práctica I-1: Introducción ...................................................................... 5
Prácticas de la Lección 1......................................................................................................... 11
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Práctica 1-1: Recuperación de Datos mediante la Sentencia SQL SELECT ................ 12


Soluciones a la Práctica 1-1: Recuperación de Datos mediante la Sentencia SQL
SELECT ........................................................................................................................ 16
Prácticas de la Lección 2......................................................................................................... 19
Práctica 2-1: Restricción y Ordenación de Datos ......................................................... 20
Soluciones a la Práctica 2-1: Restricción y Ordenación de Datos ................................ 24
Prácticas de la Lección 3......................................................................................................... 27
Práctica 3-1: Uso de Funciones de Una Sola Fila para Personalizar la Salida ............. 28
Soluciones a la Práctica 3-1: Uso de Funciones de Una Sola Fila para s a
Personalizar la Salida.................................................................................................... 32 ) ha
l ฺ c om
Prácticas de la Lección 4......................................................................................................... 35

t m ai eฺ
Práctica 4-1: Uso de Funciones de Conversión y Expresiones Condicionales............. 36
ho Guid
Soluciones a la Práctica 4-1: Uso de Funciones de Conversión y Expresiones
Condicionales................................................................................................................ 39
@
4 4 ent
Prácticas de la Lección 5......................................................................................................... 41
8
a r d0 Stud
Práctica 5-1: Informes de Datos Agregados con Funciones de Grupo ......................... 42

( r ich this
Soluciones a la Práctica 5-1: Informes de Datos Agregados con Funciones de
Grupo ............................................................................................................................ 45
i r ez use
Prácticas de la Lección 6......................................................................................................... 48
R am se to Práctica 6-1: Visualización de Datos de Varias Tablas Utilizando Uniones ................ 49

o p ez licen Soluciones a la Práctica 6-1: Visualización de Datos de Varias Tablas Utilizando


Uniones ......................................................................................................................... 52
r d o L rable Prácticas de la Lección 7......................................................................................................... 54

R ica nsfe Práctica 7-1: Uso de Subconsultas para Solucionar Consultas..................................... 55

c s on n-tra Soluciones a la Práctica 7-1: Uso de Subconsultas para Solucionar Consultas............ 57


Prácticas de la Lección 8......................................................................................................... 59
i no
Ed Práctica 8-1: Uso de los Operadores de Definición ...................................................... 60
Soluciones a la Práctica 8-1: Uso de los Operadores de Definición............................. 62
Prácticas de la Lección 9......................................................................................................... 64
Práctica 9-1: Manipulación de Datos............................................................................ 65
Soluciones a la Práctica 9-1: Manipulación de Datos................................................... 69
Prácticas de la Lección 10....................................................................................................... 73
Práctica 10-1: Uso de Sentencias DDL para Crear y Gestionar Tablas........................ 74
Soluciones a la Práctica 10-1: Uso de Sentencias DDL para Crear y Gestionar
Tablas............................................................................................................................ 76
Prácticas de la Lección 11....................................................................................................... 79
Práctica 11-1: Creación de Otros Objetos de Esquema ................................................ 80
Soluciones a la Práctica 11-1: Creación de Otros Objetos de Esquema ....................... 82
Prácticas del Apéndice F......................................................................................................... 84
Práctica F-1: Sintaxis de Unión en Oracle.................................................................... 85
Soluciones a las Prácticas F-1: Sintaxis de Unión en Oracle........................................ 88

Oracle Database: Conceptos Fundamentales de SQL I A-2


Prácticas para la Lección I
En esta práctica, realizará las siguientes tareas:
• Iniciar Oracle SQL Developer y crear una nueva conexión a la cuenta ora1.
• Utilizar Oracle SQL Developer para examinar objetos de datos en la cuenta ora1.
La cuenta ora1 contiene las tablas de esquema HR.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Observe la siguiente ubicación de los archivos de los ejercicios prácticos:


\home\oracle\labs\sql1\labs
Si se le pide que guarde algún archivo de los ejercicios prácticos, guárdelo en esta
ubicación.

En las prácticas, puede que haya ejercicios que estén precedidos por las frases “Si tiene
tiempo” o “Si desea superarse a sí mismo”. Realice estos ejercicios sólo si ha terminado s a
el resto de ejercicios en el tiempo asignado y si desea poner a prueba sus habilidades. ) ha
l ฺ c om
Realice las prácticas despacio y de forma precisa. Puede experimentar guardando
t m ai y eฺ
ejecutando los archivos de comandos. Si tiene alguna duda en cualquieromomento,d
pregunte a su instructor. @ h Gui
8 4 4 ent
Nota
a r d0 Stud
1) Todas las prácticas escritas utilizan Oracle ( r ch Developer
iSQL this como entorno de
desarrollo. Aunque se recomienda i r z
e Oracle
utilizar u e
s SQL Developer, también puede usar
SQL*Plus, disponible en esteam curso.
e t o
R s
o ez la secuencia
2) Para cualquier consulta,
p l i c en de filas recuperadas de la base de datos puede
L a blalque
variar con respecto
o e se muestra en las capturas de pantalla.
i c ard sfera
n R ran
i c s o
o n -t
Ed n

Oracle Database: Conceptos Fundamentales de SQL I A-3


Práctica I-1: Introducción
Ésta es la primera de varias prácticas de este curso. Las soluciones (si las necesita) están
al final de esta práctica. Las prácticas están destinadas a abarcar la mayoría de los temas
que se presentan en la lección correspondiente.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Inicio de Oracle SQL Developer


1) Inicie Oracle SQL Developer mediante el icono del escritorio de SQL Developer.
Creación de Nuevas Conexiones a la Base de Datos de Oracle SQL Developer
2) Para crear una nueva conexión a la base de datos, en el navegador de conexiones,
haga clic con el botón derecho del mouse en Connections. Seleccione New
Connection en el menú. Aparece el cuadro de diálogo New/Select Database
Connection. a
s
3) Cree una conexión a la base de datos con la siguiente información: ) ha
a) Connection Name: myconnection l ฺ c om
b) Username: ora1 t m ai eฺ
@ ho Guid
c) Password: ora1
8 4 4 ent
d) Hostname: localhost
a r d0 Stud
e) Port: 1521 ( r ich this
f) SID: ORCL i r ez use
a m e to
R
Asegúrese de activar la casilla
z deccontrol ns Save Password.
p e e
llai Conexión a la Base de Datos de Oracle SQL
o
Prueba y Conexión Lomediante
l e
Developer
c a rd ferab
R i n s
o n
4) Pruebe
- t r
laanueva conexión.
c s n
i 5) nSioel estado es Success, conéctese a la base de datos mediante esta nueva conexión.
Ed
Examen de Tablas en el Navegador de Conexiones
6) En el navegador de conexiones, visualice los objetos disponibles en el nodo Tables.
Verifique que las siguientes tablas están presentes:
COUNTRIES
DEPARTMENTS
EMPLOYEES
JOB_GRADES
JOB_HISTORY
JOBS
LOCATIONS
REGIONS
7) Examine la estructura de la tabla EMPLOYEES.
8) Visualice los datos de la tabla DEPARTMENTS.

Oracle Database: Conceptos Fundamentales de SQL I A-4


Soluciones a la Práctica I-1: Introducción
Inicio de Oracle SQL Developer
1) Inicie Oracle SQL Developer mediante el icono del escritorio de SQL Developer.
a) Haga doble clic en el icono del escritorio de SQL Developer.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Aparece la interfaz de SQL Developer.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Creación de Nuevas Conexiones a la Base de Datos de Oracle SQL Developer
2) Para crear una nueva conexión a la base de datos, en el navegador de conexiones,
haga clic con el botón derecho del mouse en Connections y seleccione New
Connection en el menú.

Oracle Database: Conceptos Fundamentales de SQL I A-5


Soluciones a la Práctica I-1: Introducción (continuación)
Aparece el cuadro de diálogo New/Select Database Connection.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 44 dent
3) Cree una conexión a la base de datos con la siguiente0información:
a) Connection Name: myconnection cha
rd Stu
z ( ri e this
b) Username: ora1
m ire to us
c) Password: ora1
z Ra nse
p e lice
d) Hostname: localhost
o
e) Port:r d o L rable
1521
R ica ORCL
f) SID:a n sfe
s n
oAsegúrese
- tr
d i c n n
o de activar la casilla de control Save Password.
E

Oracle Database: Conceptos Fundamentales de SQL I A-6


Soluciones a la Práctica I-1: Introducción (continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho SQL
Prueba y Conexión mediante la Conexión a la Base de Datos de Oracle
G u id
Developer
8 4 4 ent
4) Pruebe la nueva conexión.
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

5) Si el estado es Success, conéctese a la base de datos mediante esta nueva conexión.

Oracle Database: Conceptos Fundamentales de SQL I A-7


Soluciones a la Práctica I-1: Introducción (continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
hode SQL
Al crear una conexión, automáticamente se abre una hoja de trabajo
@ G
id
upara
dicha conexión. 8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Examen de Tablas en el Navegador de Conexiones


6) En el navegador de conexiones, visualice los objetos disponibles en el nodo Tables.
Verifique que las siguientes tablas están presentes:
COUNTRIES
DEPARTMENTS
EMPLOYEES
JOB_GRADES
JOB_HISTORY
JOBS
LOCATIONS
REGIONS

Oracle Database: Conceptos Fundamentales de SQL I A-8


Soluciones a la Práctica I-1: Introducción (continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
7) Examine la estructura de la tabla EMPLOYEES.
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

8) Visualice los datos de la tabla DEPARTMENTS.

Oracle Database: Conceptos Fundamentales de SQL I A-9


Soluciones a la Práctica I-1: Introducción (continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-10


Prácticas de la Lección 1
En esta práctica, escribirá consultas simples SELECT. Las consultas tratan la mayoría de
las operaciones y cláusulas SELECT que ha aprendido en esta lección.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-11


Práctica 1-1: Recuperación de Datos mediante la Sentencia SQL
SELECT
Parte 1

Ponga a prueba sus conocimientos:


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

1) La siguiente sentencia SELECT se ejecuta correctamente:


SELECT last_name, job_id, salary AS Sal
FROM employees;

Verdadero/Falso

s a
2) La siguiente sentencia SELECT se ejecuta correctamente:
) ha
SELECT *
l ฺ c om
FROM job_grades;
t m ai eฺ
@ ho Guid
Verdadero/Falso 8 4 4 ent
a r d0 Stud
( r
3) En la siguiente sentencia hay cuatro errores icdehcodificación.
this ¿Puede identificarlos?
z
re o us
ilast_name e
SELECT employee_id, m
a se t
sal x 12 ANNUAL SALARY R
FROM ez licen
employees;
o p
r d o L rable
Parte
R i2ca nsfe
s oTenga n tra los siguientes puntos antes de iniciar las prácticas:
n en-cuenta
i c n•o Guarde todos los archivos de los ejercicios prácticos en la siguiente ubicación:
Ed
/home/oracle/labs/sql1/labs
• Introduzca las sentencias SQL en una hoja de trabajo de SQL. Para guardar un
script en SQL Developer, asegúrese de que la hoja de trabajo de SQL necesaria
está activa y, a continuación, en el menú File, seleccione Save As para guardar la
sentencia SQL como un script lab_<lessonno>_<stepno>.sql. Cuando esté
modificando un script existente, asegúrese de que utiliza Save As para guardarlo
con un nombre de archivo diferente.
• Para ejecutar una consulta, haga clic en el icono Execute Statement en la hoja de
trabajo de SQL. Como alternativa, puede pulsar [F9]. Para sentencias DML y
DDL, utilice el icono Run Script o pulse [F5].
• Una vez ejecutada la consulta, asegúrese de que no introduce la siguiente consulta
en la misma hoja de trabajo. Abra una hoja de trabajo nueva.
Se le ha contratado como programador de SQL para Acme Corporation. Su primera tarea
es crear algunos informes según los datos de las tablas de recursos humanos.

Oracle Database: Conceptos Fundamentales de SQL I A-12


Práctica 1-1: Recuperación de Datos mediante la Sentencia SQL
SELECT (continuación)
4) Su primera tarea es determinar la estructura de la tabla DEPARTMENTS y su contenido.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
5) Determine la estructura de la tabla EMPLOYEESa . rd
0 tud
r i c h his S
z ( e t
r e s
a mi e to u
z R ns
o p e l i c e
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

El departamento de recursos humanos desea que una consulta muestre el apellido, ID


de cargo, fecha de contratación e ID de empleado de cada empleado, con el ID de
empleado en primer lugar. Proporcione un alias STARTDATE para la columna
HIRE_DATE. Guarde la sentencia SQL en un archivo con el nombre
lab_01_05.sql para distribuirlo al departamento de recursos humanos.
6) Pruebe la consulta en el archivo lab_01_05.sql para asegurarse de que se ejecuta
correctamente.
Nota: una vez ejecutada la consulta, asegúrese de que no introduce la siguiente
consulta en la misma hoja de trabajo. Abra una hoja de trabajo nueva.

Oracle Database: Conceptos Fundamentales de SQL I A-13


Práctica 1-1: Recuperación de Datos mediante la Sentencia SQL
SELECT (continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

7) El departamento de recursos humanos desea una consulta para mostrar todos los ID s a
de cargo únicos de la tabla EMPLOYEES. ) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i Parteno3
Ed
Si tiene tiempo, realice los siguientes ejercicios:
8) El departamento de recursos humanos desea cabeceras de columna más descriptivas
para su informe sobre empleados. Copie la sentencia de lab_01_05.sql en una
nueva hoja de trabajo de SQL. Asigne a las cabeceras de columna los nombres Emp
#, Employee, Job y Hire Date, respectivamente. A continuación, vuelva a ejecutar
la consulta.

Oracle Database: Conceptos Fundamentales de SQL I A-14


Práctica 1-1: Recuperación de Datos mediante la Sentencia SQL
SELECT (continuación)

9) El departamento de recursos humanos ha solicitado un informe de todos los


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

empleados y sus ID de cargo. Muestre el apellido concatenado con el ID de cargo


(separado por una coma y un espacio) y asigne a la columna el nombre Employee
and Title.

s a
) ha
l ฺ c om

t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r
Si desea superarse a sí mismo, complete el siguienteich ejercicio:
this
z
iderela tabla us e
m
a seSepare cada salida, cree
10) Para familiarizarse con los datos t o EMPLOYEES una consulta para
mostrar todos los datos deRdicha tabla. de la columna por una
coma. Asigne a lap
o ez lelictítulo
columna en THE_OUTPUT.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-15


Soluciones a la Práctica 1-1: Recuperación de Datos mediante la
Sentencia SQL SELECT
Parte 1

Ponga a prueba sus conocimientos:


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

1) La siguiente sentencia SELECT se ejecuta correctamente:


SELECT last_name, job_id, salary AS Sal
FROM employees;

Verdadero/Falso

s a
2) La siguiente sentencia SELECT se ejecuta correctamente:
) ha
SELECT *
l ฺ c om
FROM job_grades;
t m ai eฺ
@ ho Guid
Verdadero/Falso 8 4 4 ent
a r d0 Stud
( r
3) En la siguiente sentencia hay cuatro errores icdehcodificación.
this ¿Puede identificarlos?
z
re o us
ilast_name e
SELECT employee_id, m
a se t
sal x 12 ANNUAL SALARY R
FROM p ez licen
employees;
o
L ble
o EMPLOYEES
ƒ La a r d
tabla
e ra no contiene ninguna columna denominada sal. La
i c
R columna s f
n se denomina SALARY.
o n t r a
d ics nƒonEl- operador de multiplicación es *, no x, como se muestra en la línea 2.
E
ƒ El alias ANNUAL SALARY no puede incluir espacios. El alias debe ser
ANNUAL_SALARY o se deben incluir entre comillas dobles.

ƒ Falta una coma tras la columna LAST_NAME.


Parte 2
Se le ha contratado como programador de SQL para Acme Corporation. Su primera tarea
es crear algunos informes según los datos de las tablas de recursos humanos.
4) Su primera tarea es determinar la estructura de la tabla DEPARTMENTS y su contenido.

a. Para determinar la estructura de la tabla DEPARTMENTS:


DESCRIBE departments

Oracle Database: Conceptos Fundamentales de SQL I A-16


Soluciones a la Práctica 1-1: Recuperación de Datos mediante
la Sentencia SQL SELECT (continuación)
b. Para ver los datos que contiene la tabla DEPARTMENTS:
SELECT *
FROM departments;
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

5) Determine la estructura de la tabla EMPLOYEES.


DESCRIBE employees

El departamento de recursos humanos desea que una consulta muestre el apellido, ID


de cargo, fecha de contratación e ID de empleado de cada empleado, con el ID de
empleado en primer lugar. Proporcione un alias STARTDATE para la columna
HIRE_DATE. Guarde la sentencia SQL en un archivo con el nombre
s a
lab_01_05.sql para distribuirlo al departamento de recursos humanos.
) ha
c
SELECT employee_id, last_name, job_id, hire_date StartDate
l ฺ om
FROM employees;
t m ai eฺ
6) Pruebe la consulta en el archivo lab_01_05.sql para asegurarse o que seuejecuta
hde id
correctamente. 4 @
4 ent G
8
d0hire_date
ud StartDate
SELECT employee_id, last_name, job_id, a r S t
FROM employees;
( r ich this
7) El departamento de recursos humanosi r ezdeseauuna
seconsulta para mostrar todos los ID
am se .to
de cargo únicos de la tabla EMPLOYEES
R
SELECT DISTINCT
o p ezjob_idl i c en
FROM
r d o L rable
employees;

R ica nsfe
s n 3 -tra
oParte
d c ontiempo, realice los siguientes ejercicios:
i Si ntiene
E
8) El departamento de recursos humanos desea cabeceras de columna más descriptivas
para su informe sobre empleados. Copie la sentencia de lab_01_05.sql en una
nueva hoja de trabajo de SQL. Asigne a las cabeceras de columna los nombres Emp
#, Employee, Job y Hire Date, respectivamente. A continuación, vuelva a ejecutar
la consulta.
SELECT employee_id "Emp #", last_name "Employee",
job_id "Job", hire_date "Hire Date"
FROM employees;

9) El departamento de recursos humanos ha solicitado un informe de todos los


empleados y sus ID de cargo. Muestre el apellido concatenado con el ID de cargo
(separado por una coma y un espacio) y asigne a la columna el nombre Employee
and Title.
SELECT last_name||', '||job_id "Employee and Title"
FROM employees;

Oracle Database: Conceptos Fundamentales de SQL I A-17


Soluciones a la Práctica 1-1: Recuperación de Datos mediante
la Sentencia SQL SELECT (continuación)
Si desea superarse a sí mismo, complete el siguiente ejercicio:
10) Para familiarizarse con los datos de la tabla EMPLOYEES, cree una consulta para
mostrar todos los datos de dicha tabla. Separe cada salida de la columna por una
coma. Asigne a la columna el título THE_OUTPUT.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT employee_id || ',' || first_name || ',' || last_name


|| ',' || email || ',' || phone_number || ','|| job_id
|| ',' || manager_id || ',' || hire_date || ','
|| salary || ',' || commission_pct || ',' ||
department_id
THE_OUTPUT
FROM employees;
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-18


Prácticas de la Lección 2
En esta práctica se crean más informes, incluyendo sentencias que utilizan las cláusulas
WHERE y ORDER BY. Puede hacer que las sentencias SQL sean más reutilizables y
genéricas incluyendo la sustitución con ampersand.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-19


Práctica 2-1: Restricción y Ordenación de Datos
El departamento de recursos humanos necesita su ayuda para crear algunas consultas.
1) Debido a problemas presupuestarios, el departamento de recursos humanos necesita
un informe que muestre el apellido y el salario de los empleados que ganan más de
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

12.000 dólares. Guarde la sentencia SQL como un archivo denominado


lab_02_01.sql. Ejecute la consulta.

s a
) ha
l ฺ c om
2) Abra una hoja de trabajo de SQL nueva. Cree un informe que muestre el apellido y el

t m ai eฺ
número de departamento para el número de empleado 176. Ejecute la consulta.

@ ho Guid
8 4 4 ent
a r d0 Stud
h his
(ric encontrar
3) El departamento de recursos humanosznecesita e t los empleados con salarios
tanto altos como bajos. Modifique r e u
i lab_02_01.sqls para mostrar el apellido y el
a m t o
z R nse
salario de cualquier empleado cuyo salario no esté entre 5.000 y 12.000 dólares.
Guarde la sentencia
o p eSQL como
l i c elab_02_03.sql.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

4) Cree un informe para mostrar el apellido, ID de cargo y fecha de contratación de los


empleados cuyos apellidos sean Matos y Taylor. Ordene la consulta en orden
ascendente por fecha de contratación.

Oracle Database: Conceptos Fundamentales de SQL I A-20


Práctica 2-1: Restricción y Ordenación de Datos (continuación)
5) Muestre el apellido y el ID de departamento de todos los empleados de los
departamentos 20 o 50 en orden alfabético ascendente por nombre.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

6) Modifique el archivo lab_02_03.sql para mostrar el apellido y el salario de los s a


empleados que ganan entre 5.000 y 12.000 dólares y están en el departamento 20 o ) ha
l ฺ c om
50. Etiquete las columnas Employee y Monthly Salary, respectivamente. Vuelva

t m ai eฺ
a guardar lab_02_03.sql como lab_02_06.sql. Ejecute la sentencia en el
archivo lab_02_06.sql.
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R
7) El departamento de recursos
m enecesita
ahumanos to un informe que muestre el apellido y
e z de todos
la fecha de contratación
p c e nloss empleados contratados durante el año 1994.
o Lo ble li
i c ard sfera
n R ran
i c s o
o n -t
Ed n
8) Cree un informe para mostrar el apellido y el puesto de todos los empleados que no
tienen un supervisor.

9) Cree un informe para mostrar el apellido, salario y comisión de todos los empleados que
perciben comisiones. Ordene los datos en orden descendente de salario y comisiones.
Utilice la posición numérica de la columna en la cláusula ORDER BY.

Oracle Database: Conceptos Fundamentales de SQL I A-21


Práctica 2-1: Restricción y Ordenación de Datos (continuación)
10) Los miembros del departamento de recursos humanos desean tener más flexibilidad
con las consultas que está creando. Les gustaría tener un informe que muestre el
apellido y el salario de los empleados que ganen más de una cantidad especificada por
el usuario después de una solicitud. Guarde esta consulta en un archivo denominado
lab_02_10.sql. Si introduce 12000 cuando se le solicite, el informe mostrará los
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

siguientes resultados:

s a
11) El departamento de recursos humanos desea ejecutar informes basados en un ) ha
l ฺ c om
supervisor. Cree una consulta que solicite al usuario un ID de supervisor y genere el
t m ai eฺ
ID de empleado, apellido, salario y departamento de los empleados de ese supervisor.

@ ho Guid
El departamento de recursos humanos desea ordenar el informe en una columna
seleccionada. Puede probar los datos con los siguientes valores:
8 4 4 ent
manager_id = 103, ordenado por last_name:
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licporensalary:
manager_id = 201, ordenado

r d o L rable
R ica nsfe
s n - tra = 124, ordenado por employee_id:
on manager_id
i c no
Ed

Si tiene tiempo, realice los siguientes ejercicios:


12) Muestre todos los apellidos de los empleados cuya tercera letra sea una "a".

Oracle Database: Conceptos Fundamentales de SQL I A-22


Práctica 2-1: Restricción y Ordenación de Datos (continuación)
13) Muestre los apellidos de los empleados que tengan una "a" y una "e" en su apellido.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Si desea superarse a sí mismo, complete los siguientes ejercicios:


14) Muestre el apellido, cargo y salario de todos los empleados que sean vendedores u
oficinistas en el departamento de stock y cuyos salarios no sean iguales que 2.500,
3.500 ó 7.000 dólares.
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
15) Modifique el archivo lab_02_06.sql para mostrar0 44 dsalario
el8apellido, e nt y comisión
a
de todos los empleados cuya comisión sea del 20%.
h rdVuelvaSatuguardar
lab_02_06.sql como lab_02_15.sql
( ri. cVuelva t is la sentencia en el
ahejecutar
archivo lab_02_15.sql. z
ire to us e
m
z Ra nse
o p e lice
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-23


Soluciones a la Práctica 2-1: Restricción y Ordenación de Datos
El departamento de recursos humanos necesita su ayuda para crear algunas consultas.
1) Debido a problemas presupuestarios, el departamento de recursos humanos necesita
un informe que muestre el apellido y el salario de los empleados que ganan más de
12.000 dólares. Guarde la sentencia SQL como un archivo denominado
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

lab_02_01.sql. Ejecute la consulta.


SELECT last_name, salary
FROM employees
WHERE salary > 12000;
2) Abra una hoja de trabajo de SQL nueva. Cree un informe que muestre el apellido y el
número de departamento para el número de empleado 176.
SELECT last_name, department_id s a
FROM employees
) ha
WHERE employee_id = 176;
l ฺ c om
3) El departamento de recursos humanos necesita encontrar los empleados con
t m ai salarios

tanto altos como bajos. Modifique lab_02_01.sql para mostrarheloapellido iydele
salario de todos los empleados cuyo salario no esté entre 5.000@ y 12.000 G u
dólares.
Guarde la sentencia SQL como lab_02_03.sql. 084
4 e n t
rd Stu d
h a
(ric e this
SELECT last_name, salary
FROM employees
WHERE salary NOT BETWEEN z
ire5000 us 12000;
AND
m t o
z Ra el apellido,
4) Cree un informe para mostrar
n se y Taylor.
ID de cargo y fecha de contratación de los
o p e
empleados cuyos apellidos sean
l i c eMatos Ordene la consulta en orden
ascendente por
o L ble
fecha de contratación.
SELECTa r d e ra
last_name, job_id, hire_date
R i c s f
n WHERE-tranlast_name IN ('Matos', 'Taylor')
FROM employees
s o
d ic nORDERon BY hire_date;
E 5) Muestre el apellido y el ID de departamento de todos los empleados de los
departamentos 20 o 50 en orden alfabético ascendente por nombre.
SELECT last_name, department_id
FROM employees
WHERE department_id IN (20, 50)
ORDER BY last_name ASC;
6) Modifique el archivo lab_02_03.sql para mostrar el apellido y el salario de los
empleados que ganan entre 5.000 y 12.000 dólares y están en el departamento 20 o
50. Etiquete las columnas Employee y Monthly Salary, respectivamente. Vuelva a
guardar lab_02_03.sql como lab_02_06.sql. Ejecute la sentencia en el archivo
lab_02_06.sql.
SELECT last_name "Employee", salary "Monthly Salary"
FROM employees
WHERE salary BETWEEN 5000 AND 12000
AND department_id IN (20, 50);

Oracle Database: Conceptos Fundamentales de SQL I A-24


Soluciones a la Práctica 2-1: Restricción y Ordenación de Datos
(continuación)
7) El departamento de recursos humanos necesita un informe que muestre el apellido y
la fecha de contratación de todos los empleados contratados durante el año 1994.
SELECT last_name, hire_date
FROM employees
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

WHERE hire_date LIKE '%94';

8) Cree un informe para mostrar el apellido y el puesto de todos los empleados que no
tienen un supervisor.
SELECT last_name, job_id
FROM employees
WHERE manager_id IS NULL;

9) Cree un informe para mostrar el apellido, salario y comisión de todos los empleados s a
que perciben comisiones. Ordene los datos en orden descendente de salario y ) ha
c om
comisiones. Utilice la posición numérica de la columna en la cláusula ORDER BY.
l ฺ
SELECT last_name, salary, commission_pct t m ai eฺ
FROM employees
@ ho Guid
WHERE commission_pct IS NOT NULL
8 4 4 ent
ORDER BY 2 DESC, 3 DESC;
a r d0 Stud
h hidesean
10) Los miembros del departamento de recursos
con las consultas que está creando. Les z ( r ichumanos
gustaría e t unsinforme
tener
tener más flexibilidad
que muestre el
i
apellido y el salario de los empleados r e que ganen
u s más de una cantidad especificada por
el usuario después de unaR a m t o
e utilizar la consulta creada en el ejercicio
solicitud.s(Puede
p e z
práctico 1 y modificarla). c
Guarde e n esta consulta en un archivo denominado
o l i
lab_02_10.sql
r d o L r. able
R i ca nlast_name,
SELECT s fe salary

s on WHERE
FROM
n - tra salary > &sal_amt;
employees
i c no
Ed Introduzca 12000 cuando se le solicite un valor en un cuadro de diálogo. Haga clic
en OK.

11) El departamento de recursos humanos desea ejecutar informes basados en un


supervisor. Cree una consulta que solicite al usuario un ID de supervisor y genere el ID
de empleado, apellido, salario y departamento de los empleados de ese supervisor. El
departamento de recursos humanos desea ordenar el informe en una columna
seleccionada. Puede probar los datos con los siguientes valores:

Oracle Database: Conceptos Fundamentales de SQL I A-25


Soluciones a la Práctica 2-1: Restricción y Ordenación de Datos
(continuación)
manager _id = 103, ordenado por last_name
manager_id = 201, ordenado por salary
manager_id = 124, ordenado por employee_id
SELECT employee_id, last_name, salary, department_id
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

FROM employees
WHERE manager_id = &mgr_num
ORDER BY &order_col;

Si tiene tiempo, realice los siguientes ejercicios:


12) Muestre todos los apellidos de los empleados cuya tercera letra sea una "a".
SELECT last_name
FROM employees s a
WHERE last_name LIKE '__a%'; ) ha
l ฺ c om
13) Muestre los apellidos de los empleados que tengan una "a" y una "e" en su apellido.
t m ai eฺ
SELECT
FROM
last_name
employees @ ho Guid
WHERE last_name LIKE '%a%'
8 4 4 ent
AND last_name LIKE '%e%';
a r d0 Stud
Si desea superarse a sí mismo, complete z rich e tejercicios:
los(siguientes his
m irede todos
14) Muestre el apellido, cargo y salario t o uloss empleados que sean vendedores u
Ra denstock
oficinistas en el departamento
z se y cuyo salario no sea igual que 2.500, 3.500 o
7.000 dólares. p e
o le lic e
L
SELECT
a r dolast_name,
e r ab job_id, salary
R i
FROMc s f
employees
n WHERE ranjob_id IN ('SA_REP', 'ST_CLERK')
i c so AND o n -t salary NOT IN (2500, 3500, 7000);
Ed n
15) Modifique el archivo lab_02_06.sql para mostrar el apellido, salario y comisión
de todos los empleados cuya comisión sea del 20%. Vuelva a guardar
lab_02_06.sql como lab_02_15.sql. Vuelva a ejecutar la sentencia en el
archivo lab_02_15.sql.
SELECT last_name "Employee", salary "Monthly Salary",
commission_pct
FROM employees
WHERE commission_pct = .20;

Oracle Database: Conceptos Fundamentales de SQL I A-26


Prácticas de la Lección 3
Esta práctica proporciona una variedad de ejercicios que utilizan diferentes funciones que
están disponibles para tipos de dato de carácter, de número y de fecha.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-27


Práctica 3-1: Uso de Funciones de Una Sola Fila para
Personalizar la Salida
1) Escriba una consulta para mostrar la fecha del sistema. Etiquete la columna como
Date.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Nota: si la base de datos se ubica de forma remota en una zona horaria diferente, la
salida será la fecha del sistema operativo en el que reside la base de datos.

2) El departamento de recursos humanos necesita un informe que muestre el número de


empleado, apellido, salario y salario aumentado en un 15,5% (expresado como
número entero) para cada empleado. Etiquete la columna como New Salary. Guarde
s a
la sentencia SQL en un archivo denominado lab_03_02.sql.
) ha
3) Ejecute la consulta en el archivo lab_03_02.sql.
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use

R am se to
o p ez licen
r d o L rable
ica nlasconsulta
4) Modifique
R fe lab_03_02.sql para agregar una columna que reste el
on salario
- a del nuevo. Etiquete la columna como Increase. Guarde el contenido
trantiguo
i c s n
o archivo como lab_03_04.sql. Ejecute la consulta revisada.
Ed ndel

Oracle Database: Conceptos Fundamentales de SQL I A-28


Práctica 3-1: Uso de Funciones de Una Sola Fila para
Personalizar la Salida (continuación)
5) Escriba una consulta que muestre el apellido (con la primera letra en mayúsculas y el
resto en minúsculas) y la longitud del apellido de todos los empleados cuyos nombres
empiecen por las letras "J", "A" o "M". Proporcione a cada columna una etiqueta
adecuada. Ordene los resultados por el apellido de los empleados.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Vuelva a escribir la consulta para que se le solicite al usuario que introduzca la letra
por la que empieza el apellido. Por ejemplo, si el usuario introduce "H" (en
mayúscula) cuando se le solicita que introduzca una letra, la salida debe mostrar a s a
todos los empleados cuyos apellidos empiecen por la letra "H". ) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stdeudla letra introducida no
Modifique la consulta de forma que la mayúscula/minúscula
r
afecte a la salida. La letra introducida debe
h en mayúscula
icestar his antes de que la procese
z ( e t
la consulta SELECT.
m ire to us
z Ra nse
o p e lice
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

6) El departamento de recursos humanos desea buscar la duración del contrato de cada


empleado. Para cada empleado, muestre el apellido y calcule el número de meses
entre el día de hoy y la fecha de contratación del empleado. Etiquete la columna como
MONTHS_WORKED. Ordene los resultados por el número de meses durante los que ha
trabajado. Redondee el número de meses hasta el número entero más cercano.
Nota: debido a que esta consulta depende de la fecha de ejecución, los valores de la
columna MONTHS_WORKED serán diferentes.

Oracle Database: Conceptos Fundamentales de SQL I A-29


Práctica 3-1: Uso de Funciones de Una Sola Fila para
Personalizar la Salida (continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
Si tiene tiempo, realice los siguientes ejercicios:

l ฺ c om
7) Cree una consulta para mostrar el apellido y el salario de todos los empleados.

t m ai eฺ
Formatee el salario para que tenga 15 caracteres de longitud y tenga un relleno hacia
ho Guid
la izquierda con el símbolo $. Etiquete la columna como SALARY.
@
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
… o p ez licen
r d o L rable
R ica nsfe
s traconsulta que muestre los primeros ocho caracteres de los apellidos de los
o8)n Creen-una
i c o
Ed nempleados y que indique las cantidades de sus salarios con asteriscos. Cada asterisco
significa mil dólares. Ordene los datos en orden descendente de salarios. Etiquete la
columna como EMPLOYEES_AND_THEIR_SALARIES.

Oracle Database: Conceptos Fundamentales de SQL I A-30


Práctica 3-1: Uso de Funciones de Una Sola Fila para
Personalizar la Salida (continuación)
9) Cree una consulta para mostrar el apellido y el número de semanas durante las que
han trabajado todos los empleados del departamento 90. Etiquete la columna de
número de semanas como TENURE. Trunque el valor del número de semana en 0
decimales. Muestre los registros en orden descendente de antigüedad del empleado.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Nota: el valor TENURE variará ya que depende de la fecha de ejecución de la


consulta.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-31


Soluciones a la Práctica 3-1: Uso de Funciones de Una Sola Fila
para Personalizar la Salida
1) Escriba una consulta para mostrar la fecha del sistema. Etiquete la columna como
Date.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Nota: si la base de datos se ubica de forma remota en una zona horaria diferente, la
salida será la fecha del sistema operativo en el que reside la base de datos.
SELECT sysdate "Date"
FROM dual;

2) El departamento de recursos humanos necesita un informe que muestre el número de


empleado, apellido, salario y salario aumentado en un 15,5% (expresado como
número entero) para cada empleado. Etiquete la columna como New Salary. a
s
) ha
Guarde la sentencia SQL en un archivo denominado lab_03_02.sql.
SELECT employee_id, last_name, salary,
l ฺ c om
ROUND(salary * 1.155, 0) "New Salary"
t m ai eฺ
ho Guid
FROM employees;

3) Ejecute la consulta en el archivo lab_03_02.sql. 4 @


4 ent
8
d0 Stud
SELECT employee_id, last_name, salary,
a r
ROUND(salary * 1.155, 0)
( r ich"New tSalary"
his
FROM employees; z
ire topara e
usagregar una columna que reste el
a sem
4) Modifique la consulta lab_03_02.sql
z REtiquete
cen
salario antiguo del nuevo. la columna como Increase. Guarde el
contenido delL ope como
archivo
l e l ilab_03_04.sql. Ejecute la consulta revisada.
o ab last_name, salary,
rd employee_id,
r
a
SELECT
c f e
n Ri ranROUND(salary
s * 1.155, 0) "New Salary",
o
s FROM n t
- employees; * 1.155, 0) - salary "Increase"
ROUND(salary
i c o
Ed n
5) Escriba una consulta que muestre el apellido (con la primera letra en mayúsculas y el
resto en minúsculas) y la longitud del apellido de todos los empleados cuyos nombres
empiecen por las letras "J", "A" o "M". Proporcione a cada columna una etiqueta
adecuada. Ordene los resultados por el apellido de los empleados.
SELECT INITCAP(last_name) "Name",
LENGTH(last_name) "Length"
FROM employees
WHERE last_name LIKE 'J%'
OR last_name LIKE 'M%'
OR last_name LIKE 'A%'
ORDER BY last_name ;

Vuelva a escribir la consulta para que se le solicite al usuario que introduzca la letra
por la que empieza el apellido. Por ejemplo, si el usuario introduce H (en mayúscula)
cuando se le solicita que introduzca una letra, la salida debe mostrar a todos los
empleados cuyos apellidos empiecen por la letra "H".

Oracle Database: Conceptos Fundamentales de SQL I A-32


Soluciones a la Práctica 3-1: Uso de Funciones de Una Sola Fila
para Personalizar la Salida (continuación)
SELECT INITCAP(last_name) "Name",
LENGTH(last_name) "Length"
FROM employees
WHERE last_name LIKE '&start_letter%'
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

ORDER BY last_name;

Modifique la consulta de forma que la mayúscula/minúscula de la letra introducida no


afecte a la salida. La letra introducida debe estar en mayúscula antes de que la procese
la consulta SELECT.
SELECT INITCAP(last_name) "Name",
LENGTH(last_name) "Length"
FROM employees
WHERE last_name LIKE UPPER('&start_letter%' ) s a
ORDER BY last_name;
) ha
ฺ c om
6) El departamento de recursos humanos desea buscar la duración del contrato de cada
l
t m ai eฺ
empleado. Para cada empleado, muestre el apellido y calcule el número de meses
ho Guid
entre el día de hoy y la fecha de contratación del empleado. Etiquete la columna como
@
8 4 4 ent
MONTHS_WORKED. Ordene los resultados por el número de meses durante los que ha

a r d0 Stud
trabajado. Redondee el número de meses hasta el número entero más cercano.

Nota: debido a que esta consulta depende ( r ichla fechathdeisejecución, los valores de la
de
columna MONTHS_WORKED serán i r z use
ediferentes.
R am se to
SELECT last_name, ROUND(MONTHS_BETWEEN(
SYSDATE, e
p z cen MONTHS_WORKED
hire_date))
FROM L
employeeso l e li
ORDER BY o ab
rd months_worked;
r
c a f e
n
Si Ri tiempo,
tiene r a n s
realice los siguientes ejercicios:
s o n - t
c
i 7) nCree o una consulta para mostrar el apellido y el salario de todos los empleados.
Ed Formatee el salario para que tenga 15 caracteres de longitud y tenga un relleno hacia
la izquierda con el símbolo $. Etiquete la columna como SALARY.
SELECT last_name,
LPAD(salary, 15, '$') SALARY
FROM employees;
8) Cree una consulta que muestre los primeros ocho caracteres de los apellidos de los
empleados y que indique las cantidades de sus salarios con asteriscos. Cada asterisco
significa mil dólares. Ordene los datos en orden descendente de salarios. Etiquete la
columna como EMPLOYEES_AND_THEIR_SALARIES.
SELECT rpad(last_name, 8)||' '||
rpad(' ', salary/1000+1, '*')
EMPLOYEES_AND_THEIR_SALARIES
FROM employees
ORDER BY salary DESC;

Oracle Database: Conceptos Fundamentales de SQL I A-33


Soluciones a la Práctica 3-1: Uso de Funciones de Una Sola Fila
para Personalizar la Salida (continuación)
9) Cree una consulta para mostrar el apellido y el número de semanas durante las que
han trabajado todos los empleados del departamento 90. Etiquete la columna de
número de semanas como TENURE. Trunque el valor del número de semana en 0
decimales. Muestre los registros en orden descendente de antigüedad del empleado.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Nota: el valor TENURE variará ya que depende de la fecha de ejecución de la


consulta.

SELECT last_name, trunc((SYSDATE-hire_date)/7) AS TENURE


FROM employees
WHERE department_id = 90
ORDER BY TENURE DESC
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-34


Prácticas de la Lección 4
Esta práctica proporciona una variedad de ejercicios que utilizan las funciones TO_CHAR
y TO_DATE y expresiones condicionales como DECODE y CASE. Recuerde que para las
funciones anidadas, los resultados se evalúan desde la función más profunda hasta la
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

función menos profunda.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-35


Práctica 4-1: Uso de Funciones de Conversión y Expresiones
Condicionales
1) Cree un informe que produzca los siguientes resultados para cada empleado:
<apellido_empleado> earns <salario> monthly but wants <3 veces
el salario.>. Etiquete la columna como Dream Salaries.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha

l ฺ c om
t m ai eฺ
2) Muestre el apellido, fecha de contratación y fecha de revisión de h
o cada
salario de u id
empleado, que es el primer lunes después de seis meses de 4 @ t G
4contrato.enEtiquete la
columna como REVIEW. Formatee las fechas para que 8
d0aparezcan uden un formato
a r S t
( r ich this
similar a “Lunes treinta y uno de julio de 2000”.

i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on … n-tra
i no
Ed
3) Muestre el apellido, fecha de contratación y día de la semana en el que empezó a
trabajar el empleado. Etiquete la columna como DAY. Ordene los resultados por el día
de la semana, empezando por el lunes.

Oracle Database: Conceptos Fundamentales de SQL I A-36


Práctica 4-1: Uso de Funciones de Conversión y Expresiones
Condicionales (continuación)
4) Cree una consulta que muestre los apellidos y comisiones de los empleados. Si un
empleado no obtiene ninguna comisión, indique "No Commission". Etiquete la
columna como COMM.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ


s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
Si tiene tiempo, realice los siguientes ejercicios:
a r d0 Stud
5) Con la función DECODE, escriba una consulta
( r ichque muestre
t his el grado de todos los
empleados según el valor de la columna
i r z
e JOB_ID u e
s , utilizando los siguientes datos:
Cargo am se t
Grado o
R
AD_PRES
ST_MAN o p ez ABlicen
IT_PROG o
L ble C
SA_REP r d
a sfera D
R i c
ST_CLERKn E
o n t r a
ics non-
None of the above 0
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-37


Práctica 4-1: Uso de Funciones de Conversión y Expresiones
Condicionales (continuación)
6) Vuelva a escribir la sentencia del ejercicio anterior utilizando la sintaxis CASE.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ


s a
) ha
… l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-38


Soluciones a la Práctica 4-1: Uso de Funciones de Conversión y
Expresiones Condicionales
1) Cree un informe que produzca los siguientes resultados para cada empleado:
<apellido_empleado> earns <salario> mensual pero desea<3 veces el salario.>.
Etiquete la columna como Dream Salaries.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT last_name || ' earns '


|| TO_CHAR(salary, 'fm$99,999.00')
|| ' monthly but wants '
|| TO_CHAR(salary * 3, 'fm$99,999.00')
|| '.' "Dream Salaries"
FROM employees;

2) Muestre el apellido, fecha de contratación y fecha de revisión de salario de cada


s a
empleado, que es el primer lunes después de seis meses de contrato. Etiquete la
) ha
l ฺ c om
columna como REVIEW. Formatee las fechas para que aparezcan en un formato
similar a “Lunes treinta y uno de julio de 2000”.
t m ai eฺ
SELECT last_name, hire_date,
TO_CHAR(NEXT_DAY(ADD_MONTHS(hire_date,@
ho Guid
6),'MONDAY'),
'fmDay, "the" Ddspth "of" Month, 8 4 4 REVIEW
YYYY') e n t
FROM employees;
a r d0 Stud
h de lahsemana
3) Muestre el apellido, fecha de contratación
z ( r iycdía
e t is en el que empezó a
re ocomo
trabajar el empleado. Etiquete la icolumna
m t us DAY. Ordene los resultados por el día
z Ra nse
de la semana, empezando por el lunes.
SELECT last_name,
o p e hire_date,
l i c e
o L ble
TO_CHAR(hire_date, 'DAY') DAY
FROM rd employees
i
ORDERc s f era
a BY TO_CHAR(hire_date - 1, 'd');
n R ran
so4) Creen t consulta que muestre los apellidos y comisiones de los empleados. Si un
-una
i c o
Ed nempleado no obtiene ninguna comisión, indique "No Commission". Etiquete la
columna como COMM.
SELECT last_name,
NVL(TO_CHAR(commission_pct), 'No Commission') COMM
FROM employees;

5) Con la función DECODE, escriba una consulta que muestre el grado de todos los
empleados según el valor de la columna JOB_ID, utilizando los siguientes datos:
Cargo Grado
AD_PRES A
ST_MAN B
IT_PROG C
SA_REP D
ST_CLERK E
None of the above 0

Oracle Database: Conceptos Fundamentales de SQL I A-39


Soluciones a la Práctica 4-1: Uso de Funciones de Conversión y
Expresiones Condicionales (continuación)
SELECT job_id, decode (job_id,
'ST_CLERK', 'E',
'SA_REP', 'D',
'IT_PROG', 'C',
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

'ST_MAN', 'B',
'AD_PRES', 'A',
'0')GRADE
FROM employees;

6) Vuelva a escribir la sentencia del ejercicio anterior utilizando la sintaxis CASE.


SELECT job_id, CASE job_id
WHEN 'ST_CLERK' THEN 'E'
WHEN 'SA_REP' THEN 'D'
s a
WHEN 'IT_PROG' THEN 'C'
) ha
WHEN
WHEN
'ST_MAN'
l ฺ c omTHEN
'AD_PRES' THEN
'B'
'A'
ELSE
t m ai eฺ
'0' END GRADE
FROM employees;
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-40


Prácticas de la Lección 5
Al finalizar esta práctica, debe estar familiarizado con el uso de funciones de grupo y la
selección de grupos de datos.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-41


Práctica 5-1: Informes de Datos Agregados con Funciones de
Grupo
Determine la validez de las tres sentencias siguientes. Seleccione Verdadero o Falso.
1) Las funciones de grupo funcionan en varias filas para producir un resultado por grupo.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Verdadero/Falso
2) Las funciones de grupo incluyen valores nulos en los cálculos.
Verdadero/Falso
3) La cláusula WHERE restringe las filas antes de incluirlas en un cálculo de grupo.
Verdadero/Falso

El departamento de recursos humanos necesita los siguientes informes: s a


) ha
l ฺ c om
4) Encontrar el valor más alto, el valor más bajo, la suma y la media del salario de todos

t m ai eฺ
los empleados. Etiquete las columnas como Maximum, Minimum, Sum y Average,
respectivamente. Redondee los resultados al número entero más cercano. Guarde la
ho Guid
sentencia SQL como lab_05_04.sql. Ejecute la consulta.
@
8 4 4 ent
a r d0 Stud
( r ich thpara is mostrar el valor mínimo, el
z
5) Modifique la consulta del archivo lab_05_04.sql e
e salarioudes cada tipo de cargo. Vuelva a guardar
valor máximo, la suma y la mediairdel
R a se to. Ejecute la sentencia en el archivo
m
lab_05_04.sql como lab_05_05.sql
lab_05_05.sqlp . ez c en
o l i
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-42


Práctica 5-1: Informes de Datos Agregados con Funciones de
Grupo (continuación)
6) Escriba una consulta para mostrar el número de personas con el mismo cargo.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
Generalice la consulta para preguntar al usuario del departamentohde orecursosuid
@
4 ent
humanos cuál es su puesto. Guarde el script en un archivo4denominado G
lab_05_06.sql. Ejecute la consulta. Introduzca IT_PROG d 8
0 tcuando
u d se le solicite.
r
ha his S
( r i c t
r e z s e
a
7) Determine el número de gestores t o u en una lista. Etiquete la columna
misin eenumerarlos
z R ns
Number of Managers
o p e .
l i c e
o L ble MANAGER_ID para determinar el número de gestores.
Indicación: utilice la columna

i c ard sfera
n R ran
i c o
s 8) Busque
o n -t la diferencia entre los salarios más altos y más bajos. Etiquete la columna
Ed ncomo DIFFERENCE.

Si tiene tiempo, realice los siguientes ejercicios:


9) Cree un informe para mostrar el número de gestor y el salario del empleado con
menor sueldo de ese gestor. Excluya a cualquier trabajador del que desconozca su
gestor. Excluya cualquier grupo en el que el salario mínimo sea 6.000 dólares o
menos. Ordene la salida en orden descendente de salarios.

Oracle Database: Conceptos Fundamentales de SQL I A-43


Práctica 5-1: Informes de Datos Agregados con Funciones de
Grupo (continuación)
Si desea superarse a sí mismo, complete los siguientes ejercicios:
10) Cree una consulta para mostrar el número total de empleados y, de ese total, el
número de empleados contratados en 1995, 1996, 1997 y 1998. Cree las cabeceras de
columna adecuadas.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

11) Cree una consulta de matriz para mostrar el cargo, el salario de ese cargo según el
número de departamento y el salario total del cargo para los departamentos 20, 50, 80
y 90, proporcionando a cada columna una cabecera adecuada.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-44


Soluciones a la Práctica 5-1: Informes de Datos Agregados con
Funciones de Grupo
Determine la validez de las tres sentencias siguientes. Seleccione Verdadero o Falso.
1) Las funciones de grupo funcionan en varias filas para producir un resultado por grupo.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Verdadero/Falso
2) Las funciones de grupo incluyen valores nulos en los cálculos.
Verdadero/Falso
3) La cláusula WHERE restringe las filas antes de incluirlas en un cálculo de grupo.
Verdadero/Falso

El departamento de recursos humanos necesita los siguientes informes:


s a
) ha
4) Encontrar el valor más alto, el valor más bajo, la suma y la media del salario de todos

l ฺ om
los empleados. Etiquete las columnas como Maximum, Minimum, Sum y Average,
c
respectivamente. Redondee los resultados al número entero más cercano. Guarde la
m ai eฺ
sentencia SQL como lab_05_04.sql. Ejecute la consulta.
t
SELECT ROUND(MAX(salary),0) "Maximum", @ ho Guid
ROUND(MIN(salary),0) "Minimum", 84
4 ent
ROUND(SUM(salary),0) "Sum", rd0 t ud
a S
FROM
ROUND(AVG(salary),0) "Average"
employees; ( r ich this
i r ez use
R a e to
m lab_05_04.sql
5) Modifique la consulta del archivo para mostrar el valor mínimo,
el valor máximo, la suma
e z y lacomomedia
e s del salario de cada tipo de cargo. Vuelva a
nlab_05_05.sql.
L o p
guardar lab_05_04.sql l i c Ejecute la sentencia en el
l e
a r do erab
archivo lab_05_05.sql.
ic job_id,
SELECT
R n s f ROUND(MAX(salary),0) "Maximum",
c s on n-tra ROUND(MIN(salary),0) "Minimum",
d i n o ROUND(SUM(salary),0) "Sum",
E ROUND(AVG(salary),0) "Average"
FROM employees
GROUP BY job_id;
6) Escriba una consulta para mostrar el número de personas con el mismo cargo.
SELECT job_id, COUNT(*)
FROM employees
GROUP BY job_id;
Generalice la consulta para preguntar al usuario del departamento de recursos
humanos cuál es su puesto. Guarde el script en un archivo denominado
lab_05_06.sql. Ejecute la consulta. Introduzca IT_PROG cuando se le solicite y
haga clic en OK.
SELECT job_id, COUNT(*)
FROM employees
WHERE job_id = '&job_title'
GROUP BY job_id;

Oracle Database: Conceptos Fundamentales de SQL I A-45


Soluciones a la Práctica 5-1: Informes de Datos Agregados con
Funciones de Grupo (continuación)
7) Determine el número de gestores sin enumerarlos en una lista. Etiquete la columna
como Number of Managers.
Indicación: utilice la columna MANAGER_ID para determinar el número de gestores.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT COUNT(DISTINCT manager_id) "Number of Managers"


FROM employees;

8) Busque la diferencia entre los salarios más altos y más bajos. Etiquete la columna
como DIFFERENCE.
SELECT MAX(salary) - MIN(salary) DIFFERENCE
FROM employees;

Si tiene tiempo, realice los siguientes ejercicios: s a


9) Cree un informe para mostrar el número de gestor y el salario del empleado con ) ha
ฺ c om
menor sueldo de ese gestor. Excluya a cualquier trabajador del que desconozca su
l
t m ai eฺ
gestor. Excluya cualquier grupo en el que el salario mínimo sea 6.000 dólares o
ho Guid
menos. Ordene la salida en orden descendente de salarios.
@
SELECT manager_id, MIN(salary) 8 4 4 ent
FROM employees
a r d0 Stud
manager_id IS NOT NULL ch
(ri e this
WHERE
GROUP BY manager_id
e z s
mir e to u
HAVING MIN(salary) > 6000
ORDER BY MIN(salary) aDESC;
z R ns
e e los siguientes ejercicios:
Si desea superarse aosípmismo, lcomplete
i c
10) Cree a
unar o L rque
dconsulta a le el número total de empleados y, de ese total, el
bmuestre
Rnúmero s fe contratados en 1995, 1996, 1997 y 1998. Cree las cabeceras de
ic denempleados
s on columna
n - traadecuadas.
i c o
Ed nSELECT COUNT(*) total,
SUM(DECODE(TO_CHAR(hire_date,
'YYYY'),1995,1,0))"1995",
SUM(DECODE(TO_CHAR(hire_date,
'YYYY'),1996,1,0))"1996",
SUM(DECODE(TO_CHAR(hire_date,
'YYYY'),1997,1,0))"1997",
SUM(DECODE(TO_CHAR(hire_date, 'YYYY'),1998,1,0))"1998"
FROM employees;

Oracle Database: Conceptos Fundamentales de SQL I A-46


Soluciones a la Práctica 5-1: Informes de Datos Agregados con
Funciones de Grupo (continuación)
11) Cree una consulta de matriz para mostrar el cargo, el salario de ese cargo según el
número de departamento y el salario total del cargo para los departamentos 20, 50, 80
y 90, proporcionando a cada columna una cabecera adecuada.
SELECT job_id "Job",
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SUM(DECODE(department_id , 20, salary)) "Dept 20",


SUM(DECODE(department_id , 50, salary)) "Dept 50",
SUM(DECODE(department_id , 80, salary)) "Dept 80",
SUM(DECODE(department_id , 90, salary)) "Dept 90",
SUM(salary) "Total"
FROM employees
GROUP BY job_id;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-47


Prácticas de la Lección 6
Esta práctica está destinada a proporcionarle experiencia en la extracción de datos desde
más de una tabla utilizando uniones compatibles con SQL:1999.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-48


Práctica 6-1: Visualización de Datos de Varias Tablas Utilizando
Uniones
1) Escriba una consulta para que el departamento de recursos humanos genere las
direcciones de todos los departamentos. Utilice las tablas LOCATIONS y COUNTRIES.
Muestre el ID de ubicación, dirección, ciudad, estado o provincia y país en la salida.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Utilice NATURAL JOIN para producir los resultados.

2) El departamento de recursos humanos necesita un informe sólo de los empleados con


s a
los departamentos correspondientes. Escriba una consulta para mostrar el apellido,
) ha
número y nombre de departamento de estos empleados.
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use

R am se to
o p ez licen
r d o L rable
ca nsfede recursos humanos necesita un informe de todos los empleados de
3) Elidepartamento
R
s on Toronto.
n - traMuestre el apellido, cargo, número y nombre de departamento de todos los
d i c n o
empleados que trabajan en Toronto.
E

4) Cree un informe para mostrar el apellido y número de empleado junto con el apellido
y número de gestor del empleado. Etiquete las columnas como Employee, Emp#,
Manager y Mgr#, respectivamente. Guarde la sentencia SQL como
lab_06_04.sql. Ejecute la consulta.

Oracle Database: Conceptos Fundamentales de SQL I A-49


Práctica 6-1: Visualización de Datos de Varias Tablas Utilizando
Uniones (continuación)

5) Modifique lab_06_04.sql para mostrar todos los empleados, incluido King, que no
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

tienen gestor. Ordene los resultados por número de empleado. Guarde la sentencia
SQL como lab_06_05.sql. Ejecute la consulta en el archivo lab_06_05.sql.

s a
) ha

l ฺ c om
t m ai eฺ
@ ho Guid
6) Cree un informe del departamento de recursos humanos 8 4
que
4muestre
e n t apellidos y
los
números de empleado y todos los empleados que a r d0 S
trabajen
d departamento
umismo
entel
como un empleado determinado. Proporcione
( r icha cadathcolumna
is una etiqueta adecuada.
i r e z
Guarde el script en un archivo denominado s e
lab_06_06.sql
u .
am se t o
R
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i n…o
Ed

7) El departamento de recursos humanos necesita un informe sobre los salarios y grados


de cargo. Para familiarizarse con la tabla JOB_GRADES, en primer lugar, muestre la
estructura de la tabla JOB_GRADES. A continuación, cree una consulta que muestre el
apellido, cargo, nombre de departamento, salario y grado de todos los empleados.

Oracle Database: Conceptos Fundamentales de SQL I A-50


Práctica 6-1: Visualización de Datos de Varias Tablas Utilizando
Uniones (continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Si desea superarse a sí mismo, complete los siguientes ejercicios: s a


8) El departamento de recursos humanos desea determinar los nombres de todos los ) ha
c om
empleados contratados después de Davies. Cree una consulta para mostrar el nombre
l ฺ
t m ai eฺ
y la fecha de contratación de cualquier empleado contratado después del empleado
Davies.
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
s - tra
o9)n El ndepartamento de recursos humanos necesita buscar el nombre y la fecha de
i c o
Ed ncontratación de todos los empleados contratados antes que sus gestores, junto con el
nombre y fecha de contratación del gestor. Guarde el script en un archivo
denominado lab_06_09.sql.

Oracle Database: Conceptos Fundamentales de SQL I A-51


Soluciones a la Práctica 6-1: Visualización de Datos de Varias
Tablas Utilizando Uniones
1) Escriba una consulta para que el departamento de recursos humanos genere las
direcciones de todos los departamentos. Utilice las tablas LOCATIONS y COUNTRIES.
Muestre el ID de ubicación, dirección, ciudad, estado o provincia y país en la salida.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Utilice NATURAL JOIN para producir los resultados.


SELECT location_id, street_address, city, state_province,
country_name
FROM locations
NATURAL JOIN countries;
2) El departamento de recursos humanos necesita un informe de todos los empleados.
Escriba una consulta para mostrar el apellido, número y nombre de departamento de
todos los empleados. s a
) ha
SELECT last_name, department_id, department_name
FROM employees l ฺ c om
JOIN departments
t m ai eฺ
USING (department_id);
@ ho Guid
3) El departamento de recursos humanos necesita un informe
8 4 4 todosenlost empleados de
de
Toronto. Muestre el apellido, cargo, número y nombre
a r d0 de departamento
S t ud de todos los
empleados que trabajan en Toronto.
( r ich this
SELECT e.last_name, e.job_id,
i r e z e.department_id,
u s e
d.department_name
employees e R e to
am departments
FROM
ON e z JOIN
(e.department_id e n s d
= d.department_id)
JOIN L op lle lic
locations
ON r o rab
d(d.location_id = l.location_id)
i c
WHERE a s f e
LOWER(l.city) = 'toronto';
R n
c s o4)n Creen-untrainforme para mostrar el apellido y número de empleado junto con el apellido
i nyonúmero de gestor de sus gestores. Etiquete las columnas como Employee, Emp#,
Ed Manager y Mgr#, respectivamente. Guarde la sentencia SQL como
lab_06_04.sql. Ejecute la consulta.
SELECT w.last_name "Employee", w.employee_id "EMP#",
m.last_name "Manager", m.employee_id "Mgr#"
FROM employees w join employees m
ON (w.manager_id = m.employee_id);
5) Modifique lab_06_04.sql para mostrar todos los empleados, incluido King, que no
tienen gestor. Ordene los resultados por número de empleado. Guarde la sentencia
SQL como lab_06_05.sql. Ejecute la consulta en el archivo lab_06_05.sql.
SELECT w.last_name "Employee", w.employee_id "EMP#",
m.last_name "Manager", m.employee_id "Mgr#"
FROM employees w
LEFT OUTER JOIN employees m
ON (w.manager_id = m.employee_id)
ORDER BY 2;

Oracle Database: Conceptos Fundamentales de SQL I A-52


Soluciones a la Práctica 6-1: Visualización de Datos de Varias
Tablas Utilizando Uniones (continuación)
6) Cree un informe del departamento de recursos humanos que muestre los apellidos y
números de empleado y todos los empleados que trabajen en el mismo departamento
como un empleado determinado. Proporcione a cada columna una etiqueta adecuada.
Guarde el script en un archivo denominado lab_06_06.sql. Ejecute la consulta.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT e.department_id department, e.last_name employee,


c.last_name colleague
FROM employees e JOIN employees c
ON (e.department_id = c.department_id)
WHERE e.employee_id <> c.employee_id
ORDER BY e.department_id, e.last_name, c.last_name;

7) El departamento de recursos humanos necesita un informe sobre los salarios y grados


de cargo. Para familiarizarse con la tabla JOB_GRADES, en primer lugar, muestre la s a
estructura de la tabla JOB_GRADES. A continuación, cree una consulta que muestre el ) ha
l ฺ c om
apellido, cargo, nombre de departamento, salario y grado de todos los empleados.
DESC JOB_GRADES t m ai eฺ
@ ho Guid
SELECT e.last_name, e.job_id, d.department_name,
8 4 4 ent
e.salary, j.grade_level
employees e JOIN departmentsar dd
0 tud
FROM
ON r
(e.department_id = d.department_id) i c h his S
JOIN job_grades j z ( e t
r e s
u AND j.highest_sal);
ON (e.salary BETWEEN
a mij.lowest_sal
t o
z
Si desea superarse a sí mismo,
e
Rcomplete
e n selos siguientes ejercicios:
8) El departamento L odep recursos
l e lichumanos desea determinar los nombres de todos los
r
empleados
a docontratados
e r ab después de Davies. Cree una consulta para mostrar el nombre
R c
i fecha de
y la n f
scontratación de cualquier empleado contratado después del empleado
n -t r a
i c so Davies.
o n
Ed nSELECT e.last_name, e.hire_date
FROM employees e JOIN employees davies
ON (davies.last_name = 'Davies')
WHERE davies.hire_date < e.hire_date;
9) El departamento de recursos humanos necesita buscar el nombre y la fecha de
contratación de todos los empleados contratados antes que sus gestores, junto con el
nombre y fecha de contratación del gestor. Guarde el script en un archivo
denominado lab_06_09.sql.
SELECT w.last_name, w.hire_date, m.last_name, m.hire_date
FROM employees w JOIN employees m
ON (w.manager_id = m.employee_id)
WHERE w.hire_date < m.hire_date;

Oracle Database: Conceptos Fundamentales de SQL I A-53


Prácticas de la Lección 7
En esta práctica escribirá consultas complejas utilizando sentencias SELECT anidadas.
Para las preguntas de la práctica, puede crear la consulta interna primero. Antes de
codificar la consulta externa, asegúrese de que la consulta interna se ejecuta y produce los
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

datos que anticipe.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-54


Práctica 7-1: Uso de Subconsultas para Solucionar Consultas
1) El departamento de recursos humanos necesita una consulta que solicite al usuario el
apellido de un empleado. A continuación, la consulta muestra el apellido y la fecha de
contratación de cualquier empleado en el mismo departamento del empleado cuyo
nombre se proporciona (excepto ese empleado). Por ejemplo, si el usuario introduce
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Zlotkey, se buscarán todos los empleados que trabajen con Zlotkey (excepto Zlotkey).

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 44 ydsalario
2) Cree un informe que muestre el número de empleado,0apellido e nt de todos los
empleados que ganan más del salario medio. h a rd los resultados
Ordene S tu en orden
ascendente de salario.
z (ric e this
m ire to us
z Ra nse
o p e lice
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
3) Escriba una consulta que muestre el número de empleado y el apellido de todos los
empleados que trabajan en un departamento con un empleado cuyo apellido contiene
una "u". Guarde la sentencia SQL en un archivo denominado lab_07_03.sql.
Ejecute la consulta.

Oracle Database: Conceptos Fundamentales de SQL I A-55


Práctica 7-1: Uso de Subconsultas para Solucionar Consultas
(continuación)
4) El departamento de recursos humanos necesita un informe que muestre el apellido,
número de departamento e ID de cargo de todos los empleados cuyo ID de ubicación
de departamento sea 1700.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Modifique la consulta para que se solicite al usuario un ID de ubicación. Guarde estos


s a
) ha
datos en un archivo denominado lab_07_04.sql.

l ฺ c om
5) Cree un informe para el departamento de recursos humanos que muestre el apellido y

t m ai eฺ
el salario de cada empleado que realice informes para King.

@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
6) Cree un informe para z departamento
el n de recursos humanos que muestre el número de
ope leeIDlide
departamento,Lapellido cecargo de cada empleado del departamento Executive.
o
rd ferab
c a
n Ri rans
i c so on-t
Ed n
7) Cree un informe que muestre una lista de todos los empleados cuyo salario sea mayor
que el salario de los empleados del departamento 60.
Si tiene tiempo, realice el siguiente ejercicio:
8) Modifique la consulta del archivo lab_07_03.sql para mostrar el número de
empleado, apellido y salario de todos los empleados que ganan más del salario medio
y que trabajan en un departamento con cualquier empleado cuyo apellido contiene
una "u". Vuelva a guardar lab_07_03.sql como lab_07_08.sql. Ejecute la
sentencia en el archivo lab_07_08.sql.

Oracle Database: Conceptos Fundamentales de SQL I A-56


Soluciones a la Práctica 7-1: Uso de Subconsultas para
Solucionar Consultas
1) El departamento de recursos humanos necesita una consulta que solicite al usuario el
apellido de un empleado. A continuación, la consulta muestra el apellido y la fecha de
contratación de cualquier empleado en el mismo departamento del empleado cuyo
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

nombre se proporciona (excepto ese empleado). Por ejemplo, si el usuario introduce


Zlotkey, se buscarán todos los empleados que trabajen con Zlotkey (excepto
Zlotkey).
UNDEFINE Enter_name

SELECT last_name, hire_date


FROM employees
WHERE department_id = (SELECT department_id s a
FROM employees ) ha
l ฺ c om
WHERE last_name = '&&Enter_name')
AND last_name <> '&Enter_name';
t m ai eฺ
@ ho G
2) Cree un informe que muestre el número de empleado, apellido y salario de u id los
todos

8 4 4 eenntorden
empleados que ganan más del salario medio. Ordene los resultados
ascendente de salario.
a r d0 Stud
SELECT employee_id, last_name, isalary
( r ch this
FROM employees
WHERE salary > (SELECT iAVG(salary)r ez use
FROM
R e to
am employees)
ORDER BY salary;z
p e c e ns
3) Escriba una consulta
li el número de empleado y el apellido de todos los
Lo bquelemuestre
o
i c ard que
empleados
s f e ra en un departamento con un empleado cuyo apellido contiene
trabajan
n R r a n la sentencia SQL en un archivo denominado lab_07_03.sql.
una "u". Guarde
o t
d on- la consulta.
ics nEjecute
E SELECT employee_id, last_name
FROM employees
WHERE department_id IN (SELECT department_id
FROM employees
WHERE last_name like '%u%');
4) El departamento de recursos humanos necesita un informe que muestre el apellido,
número de departamento e ID de cargo de todos los empleados cuyo ID de ubicación
de departamento sea 1700.
SELECT last_name, department_id, job_id
FROM employees
WHERE department_id IN (SELECT department_id
FROM departments
WHERE location_id = 1700);

Oracle Database: Conceptos Fundamentales de SQL I A-57


Soluciones a la Práctica 7-1: Uso de Subconsultas para
Solucionar Consultas (continuación)
Modifique la consulta para que se solicite al usuario un ID de ubicación. Guarde estos
datos en un archivo denominado lab_07_04.sql.
SELECT last_name, department_id, job_id
FROM employees
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

WHERE department_id IN (SELECT department_id


FROM departments
WHERE location_id =
&Enter_location);
5) Cree un informe para el departamento de recursos humanos que muestre el apellido y
el salario de cada empleado que realice informes para King.
SELECT last_name, salary
FROM employees s a
WHERE manager_id = (SELECT employee_id ) ha
FROM employees
l ฺ c om
WHERE last_name = 'King');
t m ai eฺ
6) Cree un informe para el departamento de recursos humanos que muestre h o el unúmero
id de
departamento, apellido e ID de cargo de cada empleado del4
4 @ nt GExecutive.
departamento
SELECT department_id, last_name, job_id0
d 8 u de
FROM employees r
ha his S t
WHERE department_id IN (SELECT r i c t
( departments
department_id
r e z
FROM
u s e
i WHEREto department_name
a m e
=
'Executive'); R
z cens
p e
7) Cree un informeoque muestre li una lista de todos los empleados cuyo salario sea mayor
o Lde los empleados
l e
a r d erab
que el salario del departamento 60.

R ic last_name
SELECT
n s f FROM employees
o n WHERE
- t r a
salary > ANY (SELECT salary
i c s o n FROM employees
Ed n WHERE department_id=60);
Si tiene tiempo, realice el siguiente ejercicio:
8) Modifique la consulta del archivo lab_07_03.sql para mostrar el número de
empleado, apellido y salario de todos los empleados que ganan más del salario medio
y que trabajan en un departamento con cualquier empleado cuyo apellido contiene
una "u". Vuelva a guardar lab_07_03.sql como lab_07_08.sql. Ejecute la
sentencia en el archivo lab_07_08.sql.
SELECT employee_id, last_name, salary
FROM employees
WHERE department_id IN (SELECT department_id
FROM employees
WHERE last_name like '%u%')
AND salary > (SELECT AVG(salary)
FROM employees);

Oracle Database: Conceptos Fundamentales de SQL I A-58


Prácticas de la Lección 8
En esta práctica escribirá consultas utilizando los operadores de definición.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-59


Práctica 8-1: Uso de los Operadores de Definición
1) El departamento de recursos humanos necesita una lista de ID de departamento que
no contienen el ID de cargo ST_CLERK. Utilice los operadores de definición para
crear este informe.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
2) El departamento de recursos humanos necesita una lista de países que no tienen ) ha
l ฺ c om
ningún departamento. Muestre el ID de país y el nombre de los países. Utilice los
operadores de definición para crear este informe.
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
3) Cree una lista de cargos para los departamentos
r i c h 50
10,
h iys20, en ese orden. Muestre los
ID de cargo y departamento mediante los
z ( operadores
e t de definición.
r e s
a mi e to u
z R ns
o p e l i c e
r d o L rable
R ica nsfe
c s on n-tra
i 4) nCreeo un informe que muestre los ID de empleado y de cargo de los empleados que
Ed actualmente tienen un puesto que es el mismo que tenían cuando fueron contratados
(es decir, han cambiado de cargo pero ahora han vuelto a su puesto original).

5) El departamento de recursos humanos necesita un informe con las siguientes


especificaciones:
• ID de departamento y apellido de todos los empleados de la tabla EMPLOYEES,
independientemente de si pertenecen o no a un departamento.
• El nombre e ID de departamento de todos los departamentos de la tabla
DEPARTMENTS, independientemente de si hay o no empleados trabajando en
dichos departamentos.
Para ello, escriba una consulta compuesta.

Oracle Database: Conceptos Fundamentales de SQL I A-60


Práctica 8-1: Uso de los Operadores de Definición
(continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-61


Soluciones a la Práctica 8-1: Uso de los Operadores de
Definición
1) El departamento de recursos humanos necesita una lista de ID de departamento que
no contienen el ID de cargo ST_CLERK. Utilice los operadores de definición para
crear este informe.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT department_id
FROM departments
MINUS
SELECT department_id
FROM employees
WHERE job_id = 'ST_CLERK'
2) El departamento de recursos humanos necesita una lista de países que no tienen
s a
ningún departamento. Muestre el ID de país y el nombre de los países. Utilice los
) ha
operadores de definición para crear este informe.
l ฺ c om
SELECT country_id,country_name a i ฺ
FROM countries t m
o uide
h
MINUS
SELECT l.country_id,c.country_name
8 4 4@ ent G
FROM locations l JOIN countries c
ON (l.country_id = c.country_id) ha
rd0 Stud
JOIN departments d
z (ric e this
ON d.location_id=l.location_id;
m ire to us
Ralos ndepartamentos
3) Cree una lista de cargos para
z selos operadores
10, 50 y 20, en ese orden. Muestre los
o p e
ID de cargo y departamento
l i c e
mediante de definición.
o L rabjob_id,
SELECTddistinct
r
le department_id
FROMa
ic nsfe
employees
R a
WHERE department_id
n UNION-trALL = 10
s o
d on DISTINCT job_id, department_id
ic nSELECT
E FROM employees
WHERE department_id = 50
UNION ALL
SELECT DISTINCT job_id, department_id
FROM employees
WHERE department_id = 20

4) Cree un informe que muestre los ID de empleado y de cargo de los empleados que
actualmente tienen un puesto que es el mismo que tenían cuando fueron contratados
(es decir, han cambiado de cargo pero ahora han vuelto a su puesto original).
SELECT employee_id,job_id
FROM employees
INTERSECT
SELECT employee_id,job_id
FROM job_history;

Oracle Database: Conceptos Fundamentales de SQL I A-62


Soluciones a la Práctica 8-1: Uso de los Operadores de
Definición (continuación)
5) El departamento de recursos humanos necesita un informe con las siguientes
especificaciones:
• ID de departamento y apellido de todos los empleados de la tabla EMPLOYEES,
independientemente de si pertenecen o no a un departamento.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• El nombre e ID de departamento de todos los departamentos de la tabla


DEPARTMENTS, independientemente de si hay o no empleados trabajando en
dichos departamentos.
Para ello, escriba una consulta compuesta.
SELECT last_name,department_id,TO_CHAR(null)
FROM employees
s a
) ha
UNION
SELECT TO_CHAR(null),department_id,department_name
FROM departments;
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-63


Prácticas de la Lección 9
En esta práctica, agregará filas a la tabla MY_EMPLOYEE, actualizará y suprimirá datos de
la tabla y controlará las transacciones. Ejecute un script para crear la tabla
MY_EMPLOYEE.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-64


Práctica 9-1: Manipulación de Datos
El departamento de recursos humanos desea que cree sentencias SQL para insertar,
actualizar y suprimir datos de los empleados. Como prototipo, utilizará la tabla
MY_EMPLOYEE, antes de proporcionar las sentencias al departamento.
Nota: para todas las sentencias DML, utilice el icono Run Script (o pulse [F5]) para ejecutar
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

la consulta. De esta forma, ve los mensajes de comentarios en la página con separadores


Script Output. Para consultas SELECT, siga utilizando el icono Execute Statement o pulse
[F9] para obtener la salida con formato en la página con separadores Results.
Inserte los datos en la tabla MY_EMPLOYEE.
1) Ejecute la sentencia en el script lab_09_01.sql para crear la tabla MY_EMPLOYEE
utilizada en esta práctica.
s a
) ha
2) Describa la estructura de la tabla MY_EMPLOYEE para identificar los nombres de las
columnas.
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica LAST_NAME
ID
n s fe FIRST_NAME USERID SALARY

c s on n-tra
i no1
Ed Patel Ralph rpatel 895

2 Dancs Betty bdancs 860

3 Biri Ben bbiri 1100

4 Newman Chad cnewman 750

5 Ropeburn Audrey aropebur 1550

3) Cree una sentencia INSERT para agregar la primera fila de datos a la tabla
MY_EMPLOYEE a partir de los siguientes datos de ejemplo. No muestre la lista de
columnas en la cláusula INSERT. No introduzca aún todas las filas.

Oracle Database: Conceptos Fundamentales de SQL I A-65


Práctica 9-1: Manipulación de Datos (continuación)
4) Rellene la tabla MY_EMPLOYEE con la segunda fila de datos de ejemplo de la lista
anterior. En esta ocasión, muestre explícitamente la lista de columnas en la cláusula
INSERT.
5) Confirme la adición a la tabla.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

6) Escriba una sentencia INSERT en un archivo de script reutilizable para cargar las
filas restantes en la tabla MY_EMPLOYEE. El script se debe solicitar para todas las
columnas (ID, LAST_NAME, FIRST_NAME, USERID y SALARY). Guarde este script en
un archivo lab_09_06.sql.
s a
7) Rellene la tabla con las dos siguientes filas de ejemplo mostradas en el paso 3
) ha
l ฺ c om
mediante la ejecución de la sentencia INSERT en el script que ha creado.
8) Confirme las adiciones a la tabla.
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
9) Convierta las adiciones de datos
R e to
amenspermanentes.
o p ez licen
Actualice y d
r o L rdatos
suprima a blede la tabla MY_EMPLOYEE.
10)R ica el napellido
Cambie s fe del empleado 3 a Drexler.
s n Cambie
o11) n - trela salario a 1.000 dólares para todos los empleados con un salario inferior a
i c o
Ed n900.
12) Verifique los cambios en la tabla.

13) Suprima Betty Dancs de la tabla MY_EMPLOYEE.


14) Confirme los cambios en la tabla.

Oracle Database: Conceptos Fundamentales de SQL I A-66


Práctica 9-1: Manipulación de Datos (continuación)

15) Confirme todos los cambios pendientes.


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Controle la transacción de datos a la tabla MY_EMPLOYEE.


16) Rellene la tabla con la última fila de datos de ejemplo mostrada en el paso 3 mediante
las sentencias del script que ha creado en el paso 6. Ejecute las sentencias en el script.
17) Confirme la adición a la tabla.
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
18) Marque un punto intermedio en el procesamiento de la 8 4 4 ent
transacción.
0 tud
a.rd
19) Suprima todas las filas de la tabla MY_EMPLOYEE
r i c h his S
20) Confirme que la tabla está vacía. z ( e t
r e u s
21) Deseche la operación DELETE a mmási reciente
t o sin desechar la operación INSERT anterior.
z R nse
e
22) Confirme que la nueva
op le lic
fila estéeintacta.
L
a r do erab
R ic nsf
c s on n-tra
i no
Ed
23) Convierta la adición de datos en permanente.
Si tiene tiempo, realice el siguiente ejercicio:
24) Modifique el script lab_09_06.sql de forma que USERID se genere
automáticamente concatenando la primera letra del primer nombre y de los primeros
siete caracteres del apellido. El USERID generado debe estar en minúscula. Por lo
tanto, no se debe solicitar el script para el USERID. Guarde este script en un archivo
denominado lab_09_24.sql.

ID LAST_NAME FIRST_NAME USERID SALARY

6 Anthony Mark manthony 1230

Oracle Database: Conceptos Fundamentales de SQL I A-67


Práctica 9-1: Manipulación de Datos (continuación)
25) Ejecute el script lab_09_24.sql para insertar el siguiente registro:

26) Confirme que se ha agregado la nueva fila con el USERID correcto.


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-68


Soluciones a la Práctica 9-1: Manipulación de Datos
Inserte los datos en la tabla MY_EMPLOYEE.
1) Ejecute la sentencia en el script lab_09_01.sql para crear la tabla MY_EMPLOYEE
utilizada en esta práctica.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

a) En el menú File, seleccione Open. En el cuadro de diálogo Open, navegue a la


carpeta /home/oracle/labs/sql1/labs y haga doble clic en
lab_09_01.sql.
b) Una vez abierta la sentencia en una hoja de trabajo de SQL, haga clic en el icono
Run Script para ejecutar el script. Aparece un mensaje que indica que la creación
de la tabla se ha realizado correctamente en la página con separadores Script
Output.
s a
) ha
2) Describa la estructura de la tabla MY_EMPLOYEE para identificar los nombres de las
columnas.
c o m
DESCRIBE my_employee l
ai eฺ ฺ
3) Cree una sentencia INSERT para agregar la primera fila de datos h
t m
otabla uid
a la
MY_EMPLOYEE a partir de los siguientes datos de ejemplo.4 No@
4 muestren tlaG
lista de
columnas en la cláusula INSERT. 8
d0 Stud e
a r
( r ich this
ID LAST_NAME r ez use USERID
FIRST_NAME
i SALARY
am se t o
R
1 Patel pez c en
Ralph rpatel 895
o l i
r d o L rable
2ica Dancs fe Betty bdancs 860
R n s
c s on n-tra
i no3
Ed Biri Ben bbiri 1100

4 Newman Chad cnewman 750

5 Ropeburn Audrey aropebur 1550

INSERT INTO my_employee


VALUES (1, 'Patel', 'Ralph', 'rpatel', 895);

4) Rellene la tabla MY_EMPLOYEE con la segunda fila de datos de ejemplo de la lista


anterior. En esta ocasión, muestre explícitamente la lista de columnas en la cláusula
INSERT.
INSERT INTO my_employee (id, last_name, first_name,
userid, salary)

Oracle Database: Conceptos Fundamentales de SQL I A-69


Soluciones a la Práctica 9-1: Manipulación de Datos
(continuación)
VALUES (2, 'Dancs', 'Betty', 'bdancs', 860);

5) Confirme las adiciones a la tabla.


SELECT *
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

FROM my_employee;

6) Escriba una sentencia INSERT en un archivo de script reutilizable para cargar las
filas restantes en la tabla MY_EMPLOYEE. El script se debe solicitar para todas las
columnas (ID, LAST_NAME, FIRST_NAME, USERID y SALARY). Guarde este script en
un archivo denominado lab_09_06.sql.
INSERT INTO my_employee
VALUES (&p_id, '&p_last_name', '&p_first_name',
s a
) ha
'&p_userid', &p_salary);

l ฺ c om
7) Rellene la tabla con las dos siguientes filas de ejemplo mostradas en el paso 3

t m ai eฺ
mediante la ejecución de la sentencia INSERT en el script que ha creado.
INSERT INTO my_employee
@ ho Guid
VALUES (&p_id, '&p_last_name', '&p_first_name',
8 4 4 ent
'&p_userid', &p_salary);
a r d0 Stud
8) Confirme las adiciones a la tabla.
( r ich this
SELECT * i r ez use
FROM my_employee;
R am se to
p ezde datos
9) Convierta las adiciones
o l i c enen permanentes.
COMMIT;
r d o L rable
R ica nsfe
s n
oActualice
n - tyrasuprima datos de la tabla MY_EMPLOYEE.
i c no
Ed 10) Cambie el apellido del empleado 3 a Drexler.
UPDATE my_employee
SET last_name = 'Drexler'
WHERE id = 3;

11) Cambie el salario a 1.000 dólares para todos los empleados con un salario inferior a 900.
UPDATE my_employee
SET salary = 1000
WHERE salary < 900;

12) Verifique los cambios en la tabla.


SELECT *
FROM my_employee;

13) Suprima Betty Dancs de la tabla MY_EMPLOYEE.


DELETE

Oracle Database: Conceptos Fundamentales de SQL I A-70


Soluciones a la Práctica 9-1: Manipulación de Datos
(continuación)
FROM my_employee
WHERE last_name = 'Dancs';
14) Confirme los cambios en la tabla.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT *
FROM my_employee;

15) Confirme todos los cambios pendientes.


COMMIT;

Controle la transacción de datos a la tabla MY_EMPLOYEE.


16) Rellene la tabla con la última fila de datos de ejemplo mostrada en el paso 3 mediante a
s
) ha
las sentencias del script que ha creado en el paso 6. Ejecute las sentencias en el script.
INSERT INTO my_employee
l ฺ c om
'&p_userid', &p_salary); t m ai eฺ
VALUES (&p_id, '&p_last_name', '&p_first_name',

@ ho Guid
17) Confirme la adición a la tabla.
8 4 4 ent
SELECT *
a r d0 Stud
FROM my_employee;
( r ich this
ez usede la transacción.
18) Marque un punto intermedio en elrprocesamiento
i
SAVEPOINT step_17; Ra
m e to
p e z cens
Lo filasbldee lalitabla MY_EMPLOYEE.
19) Suprima todas las
o
DELETE d era
army_employee;
R i
FROMc n s f
s n Confirme
o20) n - traque la tabla está vacía.
i c o
Ed nSELECT *
FROM my_employee;

21) Deseche la operación DELETE más reciente sin desechar la operación INSERT
anterior.
ROLLBACK TO step_17;

22) Confirme que la nueva fila esté intacta.


SELECT *
FROM my_employee;
23) Convierta la adición de datos en permanente.
COMMIT;

Oracle Database: Conceptos Fundamentales de SQL I A-71


Soluciones a la Práctica 9-1: Manipulación de Datos
(continuación)
Si tiene tiempo, realice el siguiente ejercicio:
24) Modifique el script lab_09_06.sql de forma que USERID se genere
automáticamente concatenando la primera letra del primer nombre y de los primeros
siete caracteres del apellido. El USERID generado debe estar en minúscula. Por lo
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

tanto, no se debe solicitar el script para el USERID. Guarde este script en un archivo
denominado lab_09_24.sql.
SET ECHO OFF
SET VERIFY OFF
INSERT INTO my_employee
VALUES (&p_id, '&&p_last_name', '&&p_first_name',
lower(substr('&p_first_name', 1, 1) ||
substr('&p_last_name', 1, 7)), &p_salary); s a
SET VERIFY ON ) ha
SET ECHO ON
l ฺ c om
UNDEFINE p_first_name
UNDEFINE p_last_name t m ai eฺ
@ ho Guid
25) Ejecute el script lab_09_24.sql para insertar el siguiente4registro:
8 4 e n t
ID LAST_NAME FIRST_NAME a r d0 StUSERID
ud SALARY
r i c h his
z ( e t
6 Anthony
i r eMark
u s manthony 1230
am
26) Confirme que se ha agregado
R la nuevae tocon el USERID correcto.
fila
p e z cens
SELECT *
o Lo ble li
FROM my_employee
WHERE d era
arID='6';
R i c n s f
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-72


Prácticas de la Lección 10
Cree nuevas tablas mediante la sentencia CREATE TABLE. Confirme que la nueva tabla
se ha agregado a la base de datos. También aprenderá a definir el estado de una tabla
como READ ONLY y, a continuación, revertir a READ/WRITE.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Nota: para todas las sentencias DDL y DML, haga clic en el icono Run Script (o pulse
[F5]) para ejecutar la consulta en SQL Developer. De esta forma, ve los mensajes de
comentarios en la página con separadores Script Output. Para consultas SELECT, siga
haciendo clic en el icono Execute Statement o pulse [F9] para obtener la salida con
formato en la página con separadores Results.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-73


Práctica 10-1: Uso de Sentencias DDL para Crear y Gestionar
Tablas
Column Name ID NAME
Key Type Primary key
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Nulls/Unique
FK Table
FK Column
Data type NUMBER VARCHAR2
Length 7 25

s a
) ha
l ฺ c om
1) Cree la tabla DEPT según el siguiente gráfico de instancias de tabla. Guarde la
m ai eฺ
sentencia en un script denominado lab_10_01.sql y, a continuación, ejecute el
t
ho Guid
script para crear la tabla. Confirme que se ha creado la tabla.
@
8 4 4 ent
a r d0 Stud
( r ich this
i r e z use
2) Rellene la tabla DEPT con datos
que necesite. R amdeslaetablato DEPARTMENTS. Incluya sólo las columnas
3) Cree la tabla EMPo p ez el siguiente
según l i c en gráfico de instancias de tabla. Guarde la
sentencia
r d o unL script
en a b le
denominado lab_10_03.sql y, a continuación, ejecute el
icaparancrear
script
R s felar tabla. Confirme que se ha creado la tabla.
s on Column
n - traName ID LAST_NAME FIRST_NAME DEPT_ID
i c o
Ed n Key Type
Nulls/Unique
FK Table DEPT
FK Column ID
Data type NUMBER VARCHAR2 VARCHAR2 NUMBER
Length 7 25 25 7

Oracle Database: Conceptos Fundamentales de SQL I A-74


Práctica 10-1: Uso de Sentencias DDL para Crear y Gestionar
Tablas (continuación)
4) Cree la tabla EMPLOYEES2 según la estructura de la tabla EMPLOYEES. Incluya sólo
las columnas EMPLOYEE_ID, FIRST_NAME, LAST_NAME, SALARY y
DEPARTMENT_ID. Asigne a las columnas de la tabla los nombres ID, FIRST_NAME,
LAST_NAME, SALARY y DEPT_ID, respectivamente.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

5) Modifique el estado de la tabla EMPLOYEES2 a sólo lectura. Tenga en cuenta que esta
opción está soportada en Oracle Database 11g.

ID FIRST_NAME LAST_NAME SALARY DEPT_ID


34 Grant Marcie 5678 10

s a
6) Intente insertar la siguiente fila en la tabla EMPLOYEES2:
) ha
Aparecerá el siguiente mensaje de error:
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
a la tabla
7) Revierta
i c s f eEMPLOYEES2 al estado de lectura/escritura. Ahora, vuelva a intentar
R
n insertar r anmisma fila. Tenga en cuenta que esta opción está soportada en Oracle
la
s o - t
d ic non 11g.
Database
E Deben aparecer los siguientes mensajes:

8) Borre la tabla EMPLOYEES2.

Oracle Database: Conceptos Fundamentales de SQL I A-75


Soluciones a la Práctica 10-1: Uso de Sentencias DDL para Crear
y Gestionar Tablas

Column Name ID NAME


Key Type Primary key
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Nulls/Unique
FK Table
FK Column
Data type NUMBER VARCHAR2
Length 7 25

s a
) ha
l ฺ c om
1) Cree la tabla DEPT según el siguiente gráfico de instancias de tabla. Guarde la
m ai eฺ
sentencia en un script denominado lab_10_01.sql y, a continuación, ejecute el
t
ho Guid
script para crear la tabla. Confirme que se ha creado la tabla.
@
CREATE TABLE dept 8 4 4 ent
(id NUMBER(7)CONSTRAINT department_id_pk
a r d0 SPRIMARY
t ud KEY,
name VARCHAR2(25));
( r ich this
Para confirmar que se ha creado la i r z y visualizar
etabla u se su estructura, ejecute el siguiente
comando:
R am se to
DESCRIBE deptpez c en
o l i
2) Rellene la
r d otablaL DEPT
a b le datos de la tabla DEPARTMENTS. Incluya sólo aquellas
con
ica que
columnas s f er
necesite.
R
n INSERT r n
aINTO
s o n - t dept
i c o
Ed n FROM departments; department_name
SELECT department_id,

3) Cree la tabla EMP según el siguiente gráfico de instancias de tabla. Guarde la


sentencia en un script denominado lab_10_03.sql y, a continuación, ejecute el
script para crear la tabla. Confirme que se ha creado la tabla.
Column Name ID LAST_NAME FIRST_NAME DEPT_ID
Key Type
Nulls/Unique
FK Table DEPT
FK Column ID
Data type NUMBER VARCHAR2 VARCHAR2 NUMBER
Length 7 25 25 7

Oracle Database: Conceptos Fundamentales de SQL I A-76


Soluciones a la Práctica 10-1: Uso de Sentencias DDL para Crear
y Gestionar Tablas (continuación)

CREATE TABLE emp


(id NUMBER(7),
last_name VARCHAR2(25),
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

first_name VARCHAR2(25),
dept_id NUMBER(7)
CONSTRAINT emp_dept_id_FK REFERENCES dept (id)
);

Para confirmar que se ha creado la tabla y ver su estructura:


DESCRIBE emp

4) Cree la tabla EMPLOYEES2 según la estructura de la tabla EMPLOYEES. Incluya sólo s a


las columnas EMPLOYEE_ID, FIRST_NAME, LAST_NAME, SALARY y ) ha
l ฺ c om
DEPARTMENT_ID. Asigne a las columnas de la tabla los nombres ID, FIRST_NAME,
LAST_NAME, SALARY y DEPT_ID, respectivamente.
t m ai eฺ
CREATE TABLE employees2 AS
@ ho Guid
SELECT employee_id id, first_name, last_name,
8 4 4 esalary,
n t
FROM
department_id dept_id
employees; a r d0 Stud
( r ich this
ez uassólo
5) Modifique el estado de la tabla EMPLOYEES2
i r e lectura.
ALTER TABLE employees2
R amREAD e to
ONLY

6) Intente insertar la p e z fila


siguiente c e nlas tabla EMPLOYEES2.
en
L o le li
ID
r o
d erab LAST_NAME SALARY
FIRST_NAME DEPT_ID
a
34ic Grant s f 10
n R r a n Marcie 5678

i c so on-t
Ed n
Aparecerá el mensaje de error “Update operation not allowed on table”. Por lo tanto,
no se le permitirá insertar ninguna fila en la tabla porque se ha asignado un estado de
sólo lectura.
INSERT INTO employees2
VALUES (34, 'Grant','Marcie',5678,10)

7) Revierta la tabla EMPLOYEES2 al estado de lectura/escritura. Ahora, vuelva a intentar


insertar la misma fila.
Ahora, debido a que a la tabla se le ha asignado un estado READ WRITE, podrá
insertar una fila en la tabla.
ALTER TABLE employees2 READ WRITE

INSERT INTO employees2


VALUES (34, 'Grant','Marcie',5678,10)

Oracle Database: Conceptos Fundamentales de SQL I A-77


Soluciones a la Práctica 10-1: Uso de Sentencias DDL para Crear
y Gestionar Tablas (continuación)
8) Borre la tabla EMPLOYEES2.
Nota: si es necesario, puede borrar una tabla con modo READ ONLY. Para probar
esto, vuelva a modificar la tabla al estado READ ONLY y, a continuación, ejecute el
comando DROP TABLE. Se borrará la tabla EMPLOYEES2.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

DROP TABLE employees2;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-78


Prácticas de la Lección 11
La Parte 1 de la práctica de esta lección ofrece varios ejercicios de creación, uso y
eliminación de vistas. Complete las preguntas de la 1 a la 6 de esta lección.
La Parte 2 de la práctica de esta lección ofrece varios ejercicios de creación y uso de una
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

secuencia, un índice y un sinónimo. Complete las preguntas de la 7 a la 10 de esta


lección.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-79


Práctica 11-1: Creación de Otros Objetos de Esquema
Parte 1
1) El personal del departamento de recursos humanos desea ocultar algunos de los datos
de la tabla EMPLOYEES. Cree una vista denominada EMPLOYEES_VU basada en los
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

números y los apellidos de los empleados y en los números de departamento de la


tabla EMPLOYEES. La cabecera del nombre de empleado debe ser EMPLOYEE.
2) Confirme que la vista funciona. Visualice el contenido de la vista EMPLOYEES_VU.

s a
) ha
l ฺ c om

t m ai eฺ
@ ho Guid
8 4 4 ent
r 0 tud
dpara
c h a
3) Con la vista EMPLOYEES_VU, escriba una consulta
i
el S
s departamento de recursos
i
(r de empleados
humanos para visualizar todos los nombres th y números de departamento.
z
ire to us e
m
z Ra nse
o p e lice
r d o L rable
R ica nsfe
c s on n-tra
i n…o
Ed

4) El departamento 50 necesita acceso a los datos de los empleados. Cree una vista con
el nombre DEPT50 que contenga los números y apellidos de los empleados y los
números de departamento de todos los empleados del departamento 50. Se le ha
pedido que etiquete las columnas de la vista como EMPNO, EMPLOYEE y DEPTNO. Por
motivos de seguridad, no permita la reasignación de un empleado a otro departamento
a través de la vista.
5) Visualice la estructura y el contenido de la vista DEPT50.

Oracle Database: Conceptos Fundamentales de SQL I A-80


Práctica 11-1: Creación de Otros Objetos de Esquema
(continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

6) Pruebe la vista. Intente reasignar Matos al departamento 80.

Parte 2
7) Necesita una secuencia que se pueda utilizar con la columna PRIMARY KEY de la
s a
tabla DEPT. La secuencia debe empezar en 200 y tener un valor máximo de 1.000.
) ha
l ฺ c om
Aplique incrementos de 10 a la secuencia. Asigne a la secuencia el nombre
DEPT_ID_SEQ.
t m ai eฺ
8) Para probar la secuencia, escriba un script para insertar dos filas en
h ola tabla uDEPT
id .
Asigne al script el nombre lab_11_08.sql. Asegúrese de4utilizar
4 @ lantsecuencia
G que
ha creado para la columna ID. Agregue dos departamentos: 8
0 Education
dcomandos u descript.y
Administration. Confirme las adiciones. Ejecutealos r
h his S t del
9) Cree un índice no único en la columna r i c t DEPT.
( de ela tabla
r e z NAME
s
i to .uLlámelo EMP.
10) Cree un sinónimo para la tabla
a mEMPLOYEES
z R nse
o p e l i c e
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-81


Soluciones a la Práctica 11-1: Creación de Otros Objetos de
Esquema
Parte 1
1) El personal del departamento de recursos humanos desea ocultar algunos de los datos
de la tabla EMPLOYEES. Cree una vista denominada EMPLOYEES_VU basada en los
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

números y los apellidos de los empleados y en los números de departamento de la


tabla EMPLOYEES. La cabecera del nombre de empleado debe ser EMPLOYEE.
CREATE OR REPLACE VIEW employees_vu AS
SELECT employee_id, last_name employee, department_id
FROM employees;
2) Confirme que la vista funciona. Visualice el contenido de la vista EMPLOYEES_VU.
SELECT * s a
FROM employees_vu; ) ha
l ฺ c om
3) Con la vista EMPLOYEES_VU, escriba una consulta para el departamento de recursos
m ai eฺ
humanos para visualizar todos los nombres de empleados y números de
t
departamento.
@ ho Guid
SELECT employee, department_id 8 4 4 ent
FROM employees_vu;
a r d0 Stud
ichde losthempleados.
4) El departamento 50 necesita acceso a los rdatos
( is Cree una vista con
el nombre DEPT50 que contenga los
i r z e
enúmerosuysapellidos de los empleados y los
números de departamento deatodos
R to
m lose empleados del departamento 50. Se le ha
solicitado que etiquetezlas columnas
p e no c e nsdelalareasignación
vista como EMPNO, EMPLOYEE y DEPTNO.
Por motivos de o
L seguridad,
l e li permita de un empleado a otro

a r do a etravés
departamento
r a bde la vista.
ic VIEW
CREATE
R n s f dept50 AS
s on nSELECT- tra employee_id empno, last_name employee,

d i c n o FROM department_id deptno


E WHERE
employees
department_id = 50
WITH CHECK OPTION CONSTRAINT emp_dept_50;
5) Visualice la estructura y el contenido de la vista DEPT50.
DESCRIBE dept50

SELECT *
FROM dept50;
6) Pruebe la vista. Intente reasignar Matos al departamento 80.
UPDATE dept50
SET deptno = 80
WHERE employee = 'Matos';

El error se debe a que la vista DEPT50 se ha creado con la restricción WITH CHECK
OPTION. De esta forma, se garantiza que la columna DEPTNO de la vista esté
protegida contra cambios.

Oracle Database: Conceptos Fundamentales de SQL I A-82


Soluciones a la Práctica 11-1: Creación de Otros Objetos de
Esquema (continuación)
Parte 2
7) Necesita una secuencia que se pueda utilizar con la columna de clave primaria de la
tabla DEPT. La secuencia debe empezar en 200 y tener un valor máximo de 1.000.
Aplique incrementos de 10 a la secuencia. Asigne a la secuencia el nombre
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

DEPT_ID_SEQ.
CREATE SEQUENCE dept_id_seq
START WITH 200
INCREMENT BY 10
MAXVALUE 1000;

8) Para probar la secuencia, escriba un script para insertar dos filas en la tabla DEPT.
Asigne al script el nombre lab_11_08.sql. Asegúrese de utilizar la secuencia que s a
ha creado para la columna ID. Agregue dos departamentos: Education y
) ha
l ฺ c om
Administration. Confirme las adiciones. Ejecute los comandos del script.
INSERT INTO dept
t m ai eฺ
VALUES (dept_id_seq.nextval, 'Education');
@ ho Guid
INSERT INTO dept 8 4 4 ent
VALUES (dept_id_seq.nextval, 'Administration');
a r d0 Stud
( r
9) Cree un índice no único en la columna NAME ichde la tabla
thisDEPT.
z
ireONtodept e
us(name);
CREATE INDEX dept_name_idx m
a se
z Rtabla n
o p e liceEMPLOYEES
10) Cree un sinónimo para la . Llámelo EMP.

o L raemp
CREATE SYNONYM
r d bleFOR EMPLOYEES;
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-83


Prácticas del Apéndice F
Esta práctica está destinada a proporcionarle experiencia práctica en la extracción de
datos desde más de una tabla utilizando sintaxis de unión en Oracle.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I A-84


Práctica F-1: Sintaxis de Unión en Oracle
1) Escriba una consulta para que el departamento de recursos humanos genere las
direcciones de todos los departamentos. Utilice las tablas LOCATIONS y COUNTRIES.
Muestre el ID de ubicación, dirección, ciudad, estado o provincia y país en la salida.
Ejecute la consulta.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

2) El departamento de recursos humanos necesita un informe de todos los empleados.


Escriba una consulta para mostrar el apellido, número y nombre de departamento de
s a
) ha
todos los empleados. Ejecute la consulta.

l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this

i r ez use
R am se to
o p ez licen
r d o L derarecursos
3) El departamento b le humanos necesita un informe de todos los empleados de
R ica Muestre
Toronto.
empleados n s
que
f e el apellido, cargo, número y nombre de departamento de todos los
trabajan en Toronto.
o n t r a
d ics non-
E
4) Cree un informe para mostrar el apellido y número de empleado junto con el apellido
y número de gestor de sus gestores. Etiquete las columnas como Employee, Emp#,
Manager y Mgr#, respectivamente. Guarde la sentencia SQL como lab_f_04.sql.

Oracle Database: Conceptos Fundamentales de SQL I A-85


Práctica F-1: Sintaxis de Unión en Oracle (continuación)
5) Modifique lab_f_04.sql para mostrar todos los empleados, incluido King, que no
tienen gestor. Ordene los resultados por número de empleado. Guarde la sentencia
SQL como lab_f_05.sql. Ejecute la consulta en el archivo lab_f_05.sql.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
c om
6) Cree un informe del departamento de recursos humanos que muestre los apellidos y
l ฺ
t m ai eฺ
números de empleado y todos los empleados que trabajen en el mismo departamento
ho Guid
como un empleado determinado. Proporcione a cada columna una etiqueta adecuada.
@
8 4 4 ent
Guarde el script en un archivo denominado lab_f_06.sql.

a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
… ard
o L rable
R ic nsfe
c s on n-tra
i no
Ed
7) El departamento de recursos humanos necesita un informe sobre los salarios y grados
de cargo. Para familiarizarse con la tabla JOB_GRADES, en primer lugar, muestre la
estructura de la tabla JOB_GRADES. A continuación, cree una consulta que muestre el
apellido, cargo, nombre de departamento, salario y grado de todos los empleados.

Oracle Database: Conceptos Fundamentales de SQL I A-86


Práctica F-1: Sintaxis de Unión en Oracle (continuación)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Si desea superarse a sí mismo, complete los siguientes ejercicios: s a


) ha
l ฺ c om
8) El departamento de recursos humanos desea determinar los nombres de todos los

t m ai eฺ
empleados contratados después de Davies. Cree una consulta para mostrar el
nombre y la fecha de contratación de cualquier empleado contratado después del
empleado Davies.
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
s - tra
o9)n El ndepartamento
d i c n o de recursos humanos necesita buscar el nombre y la fecha de
E contratación de todos los empleados contratados antes que sus gestores, junto con el
nombre y fecha de contratación del gestor. Guarde el script en un archivo
denominado lab_f_09.sql.

Oracle Database: Conceptos Fundamentales de SQL I A-87


Soluciones a las Prácticas F-1: Sintaxis de Unión en Oracle
1) Escriba una consulta para que el departamento de recursos humanos genere las
direcciones de todos los departamentos. Utilice las tablas LOCATIONS y COUNTRIES.
Muestre el ID de ubicación, dirección, ciudad, estado o provincia y país en la salida.
Ejecute la consulta.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT location_id, street_address, city, state_province,


country_name
FROM locations, countries
WHERE locations.country_id = countries.country_id;

2) El departamento de recursos humanos necesita un informe de todos los empleados.


Escriba una consulta para mostrar el apellido, número y nombre de departamento de
todos los empleados. Ejecute la consulta.
s a
SELECT e.last_name, e.department_id, d.department_name ) ha
FROM employees e, departments d
l ฺ c om
WHERE e.department_id = d.department_id;
t m ai eฺ
3) El departamento de recursos humanos necesita un informe de todos
@ holos empleados
G uid de
4 ent de todos los
Toronto. Muestre el apellido, cargo, número y nombre de4departamento
8
empleados que trabajan en Toronto.
a r d0 Stud
( r ich this
SELECT e.last_name, e.job_id, e.department_id,
d.department_name
FROM i
employees e, departmentsr ez dus,elocations l
WHERE e.department_id
R e to
am= d.department_id
AND e
d.location_id
p ns
z c= el.location_id
AND
Lo ble li= 'toronto';
LOWER(l.city)
o
4) Cree a unrd ra mostrar el apellido y número de empleado junto con el apellido
informeepara
R i c s f
n empleado y el número de gestor. Etiquete las columnas como
del gestor del
o n t r a
- , Emp#, Manager y Mgr#, respectivamente. Guarde la sentencia SQL
i c s Employee
o n
Ed ncomo lab_f_04.sql.
SELECT w.last_name "Employee", w.employee_id "EMP#",
m.last_name "Manager", m.employee_id "Mgr#"
FROM employees w , employees m
WHERE w.manager_id = m.employee_id;

5) Modifique lab_f_04.sql para mostrar todos los empleados, incluido King, que no
tienen gestor. Ordene los resultados por número de empleado. Guarde la sentencia
SQL como lab_f_05.sql. Ejecute la consulta en el archivo lab_f_05.sql.
SELECT w.last_name "Employee", w.employee_id "EMP#",
m.last_name "Manager", m.employee_id "Mgr#"
FROM employees w, employees m
WHERE w.manager_id = m.employee_id (+);

Oracle Database: Conceptos Fundamentales de SQL I A-88


Soluciones a las Prácticas F-1: Sintaxis de Unión en Oracle
(continuación)
6) Cree un informe del departamento de recursos humanos que muestre los apellidos y
números de empleado y todos los empleados que trabajen en el mismo departamento
como un empleado determinado. Proporcione a cada columna una etiqueta adecuada.
Guarde el script en un archivo denominado lab_f_06.sql.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT e1.department_id department, e1.last_name employee,


e2.last_name colleague
FROM employees e1, employees e2
WHERE e1.department_id = e2.department_id
AND e1.employee_id <> e2.employee_id
ORDER BY e1.department_id, e1.last_name, e2.last_name;

7) El departamento de recursos humanos necesita un informe sobre los salarios y grados


de cargo. Para familiarizarse con la tabla JOB_GRADES, en primer lugar, muestre la s a
estructura de la tabla JOB_GRADES. A continuación, cree una consulta que muestre el ) ha
l ฺ c om
apellido, cargo, nombre de departamento, salario y grado de todos los empleados.
DESC JOB_GRADES t m ai eฺ
@ ho Guid
SELECT e.last_name, e.job_id, d.department_name,
8 4 4 ent
FROM
e.salary, j.grade_level
employees e, departments d, a r d0 Stujd
job_grades
WHERE e.department_id = d.department_id
( r ich this
AND
ez use AND j.highest_sal;
e.salary BETWEEN j.lowest_sal
i r
a m e to
R
Si desea superarse a sí mismo,
z complete ns los siguientes ejercicios:
p e c e
li humanos desea determinar los nombre de todos los
o Lode recursos
8) El departamento
l e
empleados
a r f e r ab después de Davies. Cree una consulta para mostrar el
d contratados
R c
i y lanfecha
nombre s de contratación de cualquier empleado contratado después de
n r a
i c so on-t
Davies .

Ed nSELECT e.last_name, e.hire_date


FROM employees e , employees davies
WHERE davies.last_name = 'Davies'
AND davies.hire_date < e.hire_date;
9) El departamento de recursos humanos necesita buscar el nombre y la fecha de
contratación de todos los empleados contratados antes que sus gestores, junto con el
nombre y fecha de contratación del gestor. Etiquete las columnas como Employee,
Emp Hired, Manager y Mgr Hired, respectivamente. Guarde el script en un
archivo denominado lab_f_09.sql.
SELECT w.last_name, w.hire_date, m.last_name, m.hire_date
FROM employees w , employees m
WHERE w.manager_id = m.employee_id
AND w.hire_date < m.hire_date;

Oracle Database: Conceptos Fundamentales de SQL I A-89


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Apéndice AP
Prácticas y Soluciones adicionales
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Tabla de Contenido
Prácticas Adicionales .......................................................................................................... 3
Práctica 1-1 ..................................................................................................................... 4
Soluciones a la Práctica 1-1 .......................................................................................... 12
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Caso Práctico .................................................................................................................... 17


Práctica 2-1 ................................................................................................................... 19
Soluciones a la Práctica 2-1 .......................................................................................... 27

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-2


Prácticas Adicionales
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-3


Práctica 1-1
Estos ejercicios se pueden utilizar como práctica adicional después de tratar los siguientes
temas: sentencia SQL SELECT básica, comandos de SQL Developer básicos y funciones
SQL.
1) El departamento de recursos humanos necesita obtener los datos de todos los
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

oficinistas que se contrataron después del año 1997.

2) El departamento de recursos humanos necesita un informe de los empleados que


perciben comisiones. Muestre el apellido, el cargo, el salario y la comisión de dichos
empleados. Ordene los datos por salario en orden descendente.
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
r 0 humanos
3) Por motivos de presupuesto, el departamento de recursos
ddebe t uda losnecesita un
informe de los aumentos programados. El informea
h his S
mostrar empleados que
r
no perciben comisiones, pero que tienen(unicaumento t del 10% del salario (redondee
r e z s e
mi e to u
los salarios).
a
R ns
p e z c e
o l i
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-4


Práctica 1-1 (continuación)
4) Cree un informe de los empleados y la duración de los contratos. Muestre los
apellidos de todos los empleados junto con el número de años y de meses completos
que han estado contratados. Ordene el informe según la duración de las
contrataciones. El empleado que haya estado contratado durante más tiempo
aparecerá al principio de la lista.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
s n - tralos empleados cuyo apellido empiece por las letras "J", "K", "L" o "M".
o5)n Muestre
i c no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-5


Práctica 1-1 (continuación)
6) Cree un informe que muestre todos los empleados e indique con las palabras Yes o No
si perciben comisiones. Utilice la expresión DECODE en la consulta.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
ca nsesfpueden
Estos iejercicios
R
e utilizar como práctica adicional después de tratar los siguientes
o n
temas:
- t r a
sentencia SQL SELECT básica, comandos de SQL Developer básicos, funciones
s
ic SQL, n y funciones de grupo.
ouniones
Ed n
7) Cree un informe que muestre el nombre de departamento, el ID de ubicación, el
nombre, el cargo y el salario de los empleados que trabajan en una ubicación
concreta. Solicite al usuario la ubicación. Por ejemplo, si el usuario introduce 1800,
se obtienen los siguientes resultados:

8) Busque el número de empleados cuyo apellido termine con la letra "n". Cree dos
soluciones posibles.

Oracle Database: Conceptos Fundamentales de SQL I AP-6


Práctica 1-1 (continuación)
9) Cree un informe que muestre el nombre, la ubicación y el número de empleados de
cada departamento. Asegúrese de que el informe sólo incluye los departamentos sin
empleados.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
10) El departamento de recursos humanos necesita obtener los puestos de los ) ha
l ฺ c om
departamentos 10 y 20. Cree un informe en el que se muestren los ID de cargo de
dichos departamentos.
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
11) Cree un informe que muestre los cargos
i r ez de los
u e
sdepartamentos Administration y
Executive. Muestre tambiénaelm número de
e o
t empleados de dichos cargos. Muestre el
cargo con el mayor númeroR
z cen de s
empleados en primer lugar.
p e
o Lo ble li
i c ard sfera
n R ran
i c s o
o n -t
Ed n
Estos ejercicios se pueden utilizar como práctica adicional después de tratar los siguientes
temas: sentencias SQL SELECT básicas, comandos de SQL Developer básicos, funciones
SQL, uniones, funciones de grupo y subconsultas.
12) Muestre todos los empleados que se hayan contratado en la primera mitad del mes
(antes del 16 del mes).

Oracle Database: Conceptos Fundamentales de SQL I AP-7


Práctica 1-1 (continuación)
13) Cree un informe que muestre lo siguiente para todos los empleados: apellido, salario
y salario expresado en términos de miles de dólares.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
14) Muestre todos Llos empleados
osiguientes b le cuyo gestor tenga un salario superior a 15.000 dólares.
Muestre
a r dlos e r a datos: nombre del empleado, nombre del gestor, salario del
R i c s f
n de salario del gestor.
gestor y grado
o n t r a
d ics non-
E

Oracle Database: Conceptos Fundamentales de SQL I AP-8


Práctica 1-1 (continuación)
15) Muestre el número de departamento, nombre, número de empleados y salario medio
de todos los departamentos, junto con los nombres, salarios y cargos de los
empleados que trabajan en cada departamento.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i
16) Cree un informe que muestre el númeror ez de departamento
u se y el salario más bajo del
a m más t o
z R nse
departamento con el salario medio alto.

o p e l i c e
r d o L rable
17)R icaun informe
Cree n s feque muestre los departamentos en los que no haya ningún vendedor.
s on Incluya
n - trelanúmero y nombre de departamento, así como el ID de gestor y la ubicación
i c neno la salida.
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-9


Práctica 1-1 (continuación)
18) Cree los siguientes informes estadísticos para el departamento de recursos humanos:
incluya el número y nombre de departamento, así como el número de empleados que
trabajan en cada departamento que:
a) Contrate menos de tres empleados:
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

b) Tenga el mayor número de empleados:

s a
c) Tenga el menor número de empleados: ) ha
l ฺ c om
t m ai eฺ
@ helosalario,
G uelid
8 4 4 ent
19) Cree un informe que muestre el número de empleado, el apellido,
número de departamento y el salario medio del departamento
0 tupara
d todos los
r d
empleados.
r i c ha his S
z ( e t
r e s
a mi e to u
z R ns
o p e l i c e
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-10


Práctica 1-1 (continuación)
20) Muestre todos los empleados que se hayan contratado el día de la semana en que se
contratara el mayor número de empleados.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

21) Cree una visión general de los aniversarios según la fecha de contratación de los
empleados. Ordene los aniversarios en orden ascendente.
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-11


Soluciones a la Práctica 1-1
Estos ejercicios se pueden utilizar como práctica adicional después de tratar los siguientes
temas: sentencia SQL SELECT básica, comandos de SQL Developer básicos y funciones
SQL.
1) El departamento de recursos humanos necesita obtener los datos de todos los
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

oficinistas que se contrataron después del año 1997.


SELECT *
FROM employees
WHERE job_id = 'ST_CLERK'
AND hire_date > '31-DEC-1997';

2) El departamento de recursos humanos necesita un informe de los empleados que


perciben comisiones. Muestre el apellido, el cargo, el salario y la comisión de dichos s a
empleados. Ordene los datos por salario en orden descendente.
) ha
SELECT last_name, job_id, salary, commission_pct
l ฺ c om
FROM employees
t m ai eฺ
WHERE commission_pct IS NOT NULL
ORDER BY salary DESC; @ ho Guid
8 4 4 ent
3) Por motivos de presupuesto, el departamento de recursos
r 0 humanos
ddebe t uda losnecesita un
informe de los aumentos programados. El informe
c a
h his S
mostrar empleados que
r i
no perciben comisiones pero que tienen (un aumentot del 10% del salario (redondee los
salarios). i r ez use
SELECT 'The salary R
am se to
of '||last_name||' after a 10% raise is '
|| p e z cen
ROUND(salary*1.10) "New salary"
FROM Lo ble li
employees
o
WHERE rdcommission_pct
i c a sfera IS NULL;
4)
n R
Cree unra n de los empleados y la duración de los contratos. Muestre los
informe
s o - t
d ic nque onhan estado
apellidos de todos los empleados junto con el número de años y de meses completos
E contratados. Ordene el informe según la duración de las
contrataciones. El empleado que haya estado contratado durante más tiempo
aparecerá al principio de la lista.
SELECT last_name,
TRUNC(MONTHS_BETWEEN(SYSDATE, hire_date) / 12) YEARS,
TRUNC(MOD(MONTHS_BETWEEN(SYSDATE, hire_date), 12))
MONTHS
FROM employees
ORDER BY years DESC, MONTHS desc;
5) Muestre los empleados cuyo apellido empiece por las letras "J", "K", "L" o "M".
SELECT last_name
FROM employees
WHERE SUBSTR(last_name, 1,1) IN ('J', 'K', 'L', 'M');

Oracle Database: Conceptos Fundamentales de SQL I AP-12


Soluciones a la Práctica 1-1 (continuación)
6) Cree un informe que muestre todos los empleados e indique con las palabras Yes o No
si perciben comisiones. Utilice la expresión DECODE en la consulta.
SELECT last_name, salary,
decode(commission_pct, NULL, 'No', 'Yes') commission
FROM employees;
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Estos ejercicios se pueden utilizar como práctica adicional después de tratar los siguientes
temas: sentencia SQL SELECT básica, comandos de SQL Developer básicos, funciones
SQL, uniones y funciones de grupo.
7) Cree un informe que muestre el nombre de departamento, el ID de ubicación, el
nombre, el cargo y el salario de los empleados que trabajan en una ubicación
s a
concreta. Solicite al usuario la ubicación.
) ha
l ฺ c om
a) Introduzca 1800 para location_id cuando se le solicite.
SELECT d.department_name, d.location_id, e.last_name, t m ai eฺ
e.job_id, e.salary
@ ho Guid
FROM employees e, departments d
8 4 4 ent
WHERE
AND
e.department_id = d.department_id
d.location_id = &location_id; a r d0 Stud
h his
(ric termine
8) Busque el número de empleados cuyozapellido e t con la letra "n". Cree dos
r e s
soluciones posibles.
a mi e to u
SELECT COUNT(*) z R ns
p e c e
e li '%n';
FROM employees
o Lo blLIKE
WHERE last_name
--orard
i c s f era
n R
SELECT n
COUNT(*)
FROM-traemployees
s o
d ic nWHEREon SUBSTR(last_name, -1) = 'n';
E 9) Cree un informe que muestre el nombre, la ubicación y el número de empleados de
cada departamento. Asegúrese de que el informe sólo incluye los departamentos sin
empleados.
SELECT d.department_id, d.department_name,
d.location_id, COUNT(e.employee_id)
FROM employees e RIGHT OUTER JOIN departments d
ON e.department_id = d.department_id
GROUP BY d.department_id, d.department_name, d.location_id;

10) El departamento de recursos humanos necesita obtener los puestos de los


departamentos 10 y 20. Cree un informe en el que se muestren los ID de cargo de
dichos departamentos.
SELECT DISTINCT job_id
FROM employees
WHERE department_id IN (10, 20);

Oracle Database: Conceptos Fundamentales de SQL I AP-13


Soluciones a la Práctica 1-1 (continuación)
11) Cree un informe que muestre los cargos de los departamentos Administration y
Executive. Muestre también el número de empleados de dichos cargos. Muestre el
cargo con el mayor número de empleados en primer lugar.
SELECT e.job_id, count(e.job_id) FREQUENCY
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

FROM employees e JOIN departments d


ON e.department_id = d.department_id
WHERE d.department_name IN ('Administration', 'Executive')
GROUP BY e.job_id
ORDER BY FREQUENCY DESC;

Estos ejercicios se pueden utilizar como práctica adicional después de tratar los siguientes
temas: sentencias SQL SELECT básicas, comandos de SQL Developer básicos, funciones s a
SQL, uniones, funciones de grupo y subconsultas. ) ha
c om
12) Muestre todos los empleados que se hayan contratado en la primera mitad del mes
l ฺ
(antes del 16 del mes).
t m ai eฺ
SELECT last_name, hire_date
@ ho Guid
FROM employees
8 4 4 ent
WHERE TO_CHAR(hire_date, 'DD') < 16;d0 ud
a r S t
ichtodosthlosisempleados: apellido, salario
13) Cree un informe que muestre lo siguienterpara
(
y salario expresado en términos de e
i r z de udólares.
miles se
SELECT last_name, salary,
R to
am sTRUNC(salary,
e -3)/1000 Thousands
FROM employees;
p z
e lice n
14) Muestre todos
o
Llos empleados
le cuyo gestor tenga un salario superior a 15.000 dólares.
r d o a b
icay grado
Muestre er datos: nombre del empleado, nombre del gestor, salario del
los siguientes
s f
n Rgestor
r a n salario del gestor.
de
o t
n- e.last_name, m.last_name manager, m.salary,
d ics nSELECT
o
E j.grade_level
FROM employees e JOIN employees m
ON e.manager_id = m.employee_id
JOIN job_grades j
ON m.salary BETWEEN j.lowest_sal AND j.highest_sal
AND m.salary > 15000;

Oracle Database: Conceptos Fundamentales de SQL I AP-14


Soluciones a la Práctica 1-1 (continuación)
15) Muestre el número de departamento, nombre, número de empleados y salario medio
de todos los departamentos, junto con los nombres, salarios y cargos de los
empleados que trabajan en cada departamento.
SELECT d.department_id, d.department_name,
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

count(e1.employee_id) employees,
NVL(TO_CHAR(AVG(e1.salary), '99999.99'), 'No average'
) avg_sal,
e2.last_name, e2.salary, e2.job_id
FROM departments d RIGHT OUTER JOIN employees e1
ON d.department_id = e1.department_id
RIGHT OUTER JOIN employees e2
ON d.department_id = e2.department_id
GROUP BY d.department_id, d.department_name, e2.last_name,
s a
) ha
e2.salary,
e2.job_id
ORDER BY d.department_id, employees;
l ฺ c om
t m ai eฺ
16) Cree un informe que muestre el número de departamento y el salario
@ homásGbajouiddel
departamento con el salario medio más alto.
8 4 4 ent
SELECT department_id, MIN(salary) ard
0 tud
FROM employees
r i c h his S
GROUP BY department_id z ( e t
r e s
HAVING AVG(salary) = (SELECT
a m t ou
i MAX(AVG(salary))
FROM e employees
z R GROUP ns BY department_id);
p e c e
o
17) Cree un informe l e li los departamentos en los que no haya ningún vendedor.
Loque bmuestre
i c areld número
Incluya
s f eryanombre de departamento, así como la ubicación, en la salida.
n R r a*n
s o SELECT
- t
d ic nFROM on departments
E WHERE department_id NOT IN(SELECT department_id
FROM employees
WHERE job_id = 'SA_REP'
AND department_id IS NOT NULL);
18) Cree los siguientes informes estadísticos para el departamento de recursos humanos:
incluya el número y nombre de departamento, así como el número de empleados que
trabajan en cada departamento que:
a) Contrate menos de tres empleados:
SELECT d.department_id, d.department_name, COUNT(*)
FROM departments d JOIN employees e
ON d.department_id = e.department_id
GROUP BY d.department_id, d.department_name
HAVING COUNT(*) < 3;

Oracle Database: Conceptos Fundamentales de SQL I AP-15


Soluciones a la Práctica 1-1 (continuación)
b) Tenga el mayor número de empleados:
SELECT d.department_id, d.department_name, COUNT(*)
FROM departments d JOIN employees e
ON d.department_id = e.department_id
GROUP BY d.department_id, d.department_name
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

HAVING COUNT(*) = (SELECT MAX(COUNT(*))


FROM employees
GROUP BY department_id);

c) Tenga el menor número de empleados:


SELECT d.department_id, d.department_name, COUNT(*)
FROM departments d JOIN employees e
s a
) ha
ON d.department_id = e.department_id
GROUP BY d.department_id, d.department_name
HAVING COUNT(*) = (SELECT MIN(COUNT(*))
l ฺ c om
FROM employees
t m ai eฺ
ho Guid
GROUP BY department_id);
@
4 4 eelnsalario,
19) Cree un informe que muestre el número de empleado, el apellido,
8 t el
d0 Stupara
número de departamento y el salario medio del departamento
a r d todos los
empleados.
( r ich this
SELECT e.employee_id, e.last_name,
i r e z usee.department_id, e.salary,
AVG(s.salary)
employees e R am employees
e to s
FROM
ON e
JOIN s
z ce=ns.department_id
e.department_id
L p
o le li e.last_name, e.department_id,
GROUP BY e.employee_id,
o
rd ferab
e.salary;
c a
i todos s los empleados que se hayan contratado el día de la semana en que se
20)RMuestre a n
n r
-t el mayor número de empleados.
so contratara
i c o n
Ed nSELECT last_name, TO_CHAR(hire_date, 'DAY') day
FROM employees
WHERE TO_CHAR(hire_date, 'Day') =
(SELECT TO_CHAR(hire_date, 'Day')
FROM employees
GROUP BY TO_CHAR(hire_date, 'Day')
HAVING COUNT(*) = (SELECT MAX(COUNT(*))
FROM employees
GROUP BY TO_CHAR(hire_date,
'Day')));

21) Cree una visión general de los aniversarios según la fecha de contratación de los
empleados. Ordene los aniversarios en orden ascendente.
SELECT last_name, TO_CHAR(hire_date, 'Month DD') BIRTHDAY
FROM employees
ORDER BY TO_CHAR(hire_date, 'DDD');

Oracle Database: Conceptos Fundamentales de SQL I AP-16


Caso Práctico
En este caso práctico, creará un juego de tablas de base de datos para una aplicación de
vídeo. Después de crear las tablas, inserte, actualice y suprima registros de una base de
datos de videoclub y genere un informe. La base de datos sólo contiene las tablas
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

esenciales.
A continuación, se muestra un diagrama de las entidades y los atributos de una aplicación
de vídeo:

TITLE
de #* id
RESERVATION * title
#* res date el asunto * description
o rating s a
) ha
de
configurado o category
para l ฺ c om o release date
t m ai eฺ
@ ho disponible
G uid
8 4 4 encomo t
a r d0 Stud
responsable ( r ich tunahiscopia
de
z
ire to us e
m
a se TITLE_COPY
MEMBER ez
R n #* id
p li c e
#* id Lo e * status
*rd o
last name ab l
c a f e
i o firstnsname r el asunto de
R a
c s on n-tooraddress responsable
i o city
Ed n o phone de realizado en
* join date RENTAL
creado #* book date
para o act ret date
o exp ret date

Nota: si desea crear las tablas, puede ejecutar los comandos del script buildtab.sql en
SQL Developer. Si desea borrar las tablas, puede ejecutar los comandos del script
dropvid.sql en SQL Developer. A continuación, puede ejecutar los comandos del
script buildvid.sql en SQL Developer para crear y rellenar las tablas.
Los tres scripts SQL se encuentran en la carpeta /home/oracle/labs/sql1/labs.
• Si utiliza el script buildtab.sql para crear las tablas, empiece en el paso 4.

Oracle Database: Conceptos Fundamentales de SQL I AP-17


• Si utiliza el script dropvid.sql para eliminar las tablas de vídeos, empiece en el
paso 1.
• Si utiliza el script buildvid.sql para crear y rellenar las tablas, empiece en el
paso 6(b).
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-18


Práctica 2-1
1) Cree las tablas según el siguiente gráfico de instancias de tabla. Seleccione los tipos
de dato adecuados y asegúrese de agregar restricciones de integridad.
a) Nombre de la tabla: MEMBER
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Column_ MEMBER_ LAST_ FIRST_NAME ADDRESS CITY PHONE JOIN


Name ID NAME _
DATE
Key PK
Type
Null/ NN,U NN NN
Unique
Default System
Value Date
s a
) ha
Data NUMBER VARCHAR2 VARCHAR2 VARCHAR2 VARCHAR2 VARCHAR2 DATE
Type
Length 10 25 25
l ฺ c
100 om 30 15

t m ai eฺ
@ ho Guid
8 4 4 ent
b) Nombre de la tabla: TITLE
a r d0 Stud
Column_ TITLE_ID TITLE ( r ich thRATING
DESCRIPTION
is CATEGORY RELEASE_
Name i r e z u s e DATE
am se t o
Key PK
R
Type
Null/
ez
NN,U op NN lic
en NN
Unique
r d o L rable
Checkca f e G, PG, R, DRAMA,
R i n s NC17, NR COMEDY,
o n - t r a
i c s o n ACTION,

Ed n CHILD,
SCIFI,
DOCUMEN
TARY
Data Type NUMBER VARCHAR2 VARCHAR2 VARCHAR2 VARCHAR2 DATE

Length 10 60 400 4 20

Oracle Database: Conceptos Fundamentales de SQL I AP-19


Práctica 2-1 (continuación)

c) Nombre de la tabla: TITLE_COPY


Column COPY_ID TITLE_ID STATUS
Name
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Key PK PK,FK
Type
Null/ NN,U NN,U NN
Unique
Check AVAILABLE,
DESTROYED,
RENTED,
RESERVED
FK Ref TITLE s a
Table ) ha
FK Ref TITLE_ID
l ฺ c om
NUMBER
Col
NUMBER t m
VARCHAR2
ai eฺ
Data
Type @ ho Guid
10 Length 10 8 4 4 e15nt
a r d0 Stud
( r ich this
d) Nombre de la tabla: RENTAL irez u se
BOOK_ RMEMBER_
o
am se tCOPY_ ACT_RET_ EXP_RET_ TITLE_
Column
Name DATE
p e z ID
c e n ID DATE DATE ID
Key o L PK
o l i
d a b le PK,FK1 PK,FK2 PK,FK2
r
a sfeSystem
Type r
R icDefault n Date System Date
o n - t
Valuer a + 2 days
i c s o n
Ed n Table
FK Ref MEMBER TITLE_ TITLE_
COPY COPY
FK Ref MEMBER_I COPY_ TITLE_ID
Col D ID
Data DATE NUMBER NUMBER DATE DATE NUMBER
Type
Length 10 10 10

Oracle Database: Conceptos Fundamentales de SQL I AP-20


Práctica 2-1 (continuación)
e) Nombre de la tabla: RESERVATION

Column RES_ MEMBER_ TITLE_


Name DATE ID ID
Key PK PK,FK1 PK,FK2
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Type
Null/ NN,U NN,U NN
Unique
FK Ref MEMBER TITLE
Table
FK Ref MEMBER_ID TITLE_ID
Column
Data Type DATE NUMBER NUMBER
s a
Length 10 10
) ha
l ฺ c om
a i ฺ
2) Verifique que las tablas se han creado correctamente comprobandoo t m ide
en el navegador
de conexiones de SQL Developer. h u
8 4 4@ ent G
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-21


Práctica 2-1 (continuación)
3) Cree secuencias para identificar de forma única cada fila de las tablas MEMBER y TITLE.
a) Número de miembro para la tabla MEMBER: empezar por 101; no permitir
almacenamiento en caché de los valores. Asigne el nombre MEMBER_ID_SEQ a la
secuencia.
b) Número de título para la tabla TITLE: empezar por 92; no permitir
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

almacenamiento en caché de los valores. Asigne el nombre TITLE_ID_SEQ a la


secuencia.
c) Verifique la existencia de las secuencias en el navegador de conexiones de SQL
Developer.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
4) Agregue datos a las tablas. Cree un script para cada juego de datos que desee agregar.
a) Agregue los títulos de las películas a la tabla TITLE. Escriba un script para
introducir la información sobre las películas. Guarde las sentencias en un script
denominado lab_apcs_4a.sql. Utilice las secuencias para identificar de forma
única cada título. Introduzca las fechas de versión en formato DD-MES-AAAA.
Recuerde que las comillas simples se deben gestionar de forma especial en los
campos de caracteres. Verifique las adiciones.

Oracle Database: Conceptos Fundamentales de SQL I AP-22


Práctica 2-1 (continuación)

Title Description Rating Category Release_date


Willie and All of Willie’s friends G CHILD 05-OCT-1995
Christmas Too make a Christmas list for
Santa, but Willie has yet
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

to add his own wish list.


Alien Again Yet another installation of R SCIFI 19-MAY-1995
science fiction history.
Can the heroine save the
planet from the alien life
form?
The Glob A meteor crashes near a NR SCIFI 12-AUG-1995
small American town and
unleashes carnivorous goo
s a
in this classic.
) ha
My Day Off With a little luck and a lot PG
l ฺ c om COMEDY 12-JUL-1995
of ingenuity, a teenager
skips school for a day in
t m ai eฺ
New York.
@ ho Guid
Miracles on Ice PG 4 ent12-SEP-1995
DRAMA
A six-year-old has doubts
8 4
a r d0 Stud
about Santa Claus, but she
discovers that miracles
( r ich this
really do exist.
Soda Gang
i r ez uNRse ACTION
After discovering a cache 01-JUN-1995

R am se to of drugs, a young couple


find themselves pitted

o p ez licen against a vicious gang.


b) Agregue L a labtabla
o datos le MEMBER. Guarde las sentencias insert en un script
r d r a
a sfelab_apcs_4b.sql
R icdenominado . Ejecute los comandos del script. Asegúrese de
o n utilizar
- t r anla secuencia para agregar los números de miembro.
s on
ic nFirst_
Ed Name Last_Name Address City Phone Join_Date
Carmen Velasquez 283 King Seattle 206-899- 08-MAR-
Street 6666 1990
LaDoris Ngao 5 Modrany Bratislava 586-355- 08-MAR-
8882 1990
Midori Nagayama 68 Via Sao Paolo 254-852- 17-JUN-
Centrale 5764 1991
Mark Quick-to-See 6921 King Lagos 63-559-7777 07-APR-1990
Way
Audry Ropeburn 86 Chu Street Hong Kong 41-559-87 18-JAN-
1991
Molly Urguhart 3035 Laurier Quebec 418-542- 18-JAN-
9988 1991

Oracle Database: Conceptos Fundamentales de SQL I AP-23


Práctica 2-1 (continuación)
c) Agregue las siguientes copias de películas a la tabla TITLE_COPY:
Nota: tenga a mano los números de TITLE_ID para este ejercicio.
Title Copy_Id Status Title Copy_Id
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Willie and 1 AVAILABLE Willie and Christmas 1


Christmas Too Too
Alien Again 1 AVAILABLE Alien Again 1

2 RENTED 2

The Glob 1 AVAILABLE The Glob 1

My Day Off 1 AVAILABLE My Day Off 1


s a
2 AVAILABLE 2 ) ha
l ฺ c om
3 RENTED
t m a3i eฺ
Miracles on Ice 1 AVAILABLE @
Miracles on
ho G1uid
Ice
8 4 4 ent
Soda Gang 1 AVAILABLE rdSoda Gang
0 tud 1
h a S
z (ric e this
r
d) Agregue los siguientes alquileres
i e a la tabla
u sRENTAL:
am e o
tdiferente en función del número de secuencia.
R
Nota: el número de título puedesser
Title_ Id o p
Copy_ ez lMember_Id
i c en
o LId ble Book_date Exp_Ret_Date
r d a
R ic ns1fer
92 a 101 3 days ago 1 day ago

c s on 93 n-tra 2 101 1 day ago 1 day from now


i o
Ed n95 3 102 2 days ago Today

97 1 106 4 days ago 2 days ago

Oracle Database: Conceptos Fundamentales de SQL I AP-24


Práctica 2-1 (continuación)
5) Cree una vista con el nombre TITLE_AVAIL para mostrar los títulos de las películas,
la disponibilidad de cada copia y la fecha de devolución esperada si está alquilada.
Consulte todas las filas de la vista. Ordene los resultados por título.
Nota: los resultados pueden ser diferentes.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
6) Realice cambios en los datos de las tablas. t m ai eฺ
a) Agregue un nuevo título. La película es “Interstellar Wars”,@ ho laucategoría
que tieneG
id
PG y está clasificada como una película de ciencia 8 4 4 La efecha
ficción. n t de la versión
es 07-JUL-77. La descripción es “Futuristica r d0 Saction
interstellar t ud movie. Can the
ich Asegúrese
rebels save the humans from the evil empire?”
( r this de agregar un registro
z
de copia de título para dos copias.
re o us e
mireserva
b) Introduzca dos reservas.aUna
e t es para Carmen Velasquez, que desea
R s
o
alquilar “Soda p ez Wars”.eLa
alquilar “Interstellar
Gang”. lic
n otra es para Mark Quick-to-See, que desea
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-25


Práctica 2-1 (continuación)
7) Realice una modificación en una de las tablas.
a) Ejecute el script lab_apcs_7a.sql ubicado en la carpeta
/home/oracle/labs/sql1/labs, para agregar una columna PRICE a la tabla
TITLE para registrar el precio de venta del vídeo. Verifique las modificaciones.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
Title Price ) ha
Willie and Christmas Too 25
l ฺ c om
Alien Again 35
t m ai eฺ
The Glob 35
@ ho Guid
My Day Off 8 4
35 4 ent
Miracles on Ice a r d0 Stud
30
Soda Gang
( r ich this 35
r ez use
Interstellar Wars
i 29

b) Cree un script conzel R


am se to
nombre lab_apcs_7b.sql que contenga sentencias de
e
p actualizar e n
actualización
L opara e ic cada vídeo con un precio según la lista
llos
d o rab
proporcionada. l
Ejecute comandos del script.
r
a tenga fea mano los números de TITLE_ID para este ejercicio.
R icNota: n s
c s o8)n Creen-untrainforme que contenga el historial de alquiler de vídeos de cada cliente.
i o
Ed nAsegúrese de incluir el nombre del cliente, la película alquilada, las fechas de alquiler
y la duración de los alquileres. Calcule el número total de alquileres de todos los
clientes para el período de informe. Guarde los comandos generados por el informe
en un script lab_apcs_8.sql.
Nota: los resultados pueden ser diferentes.

Oracle Database: Conceptos Fundamentales de SQL I AP-26


Soluciones a la Práctica 2-1
1) Cree las tablas según el siguiente gráfico de instancias de tabla. Seleccione los tipos
de dato adecuados y asegúrese de agregar restricciones de integridad.
a) Nombre de la tabla: MEMBER
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

CREATE TABLE member


(member_id NUMBER(10)
CONSTRAINT member_member_id_pk PRIMARY KEY,
last_name VARCHAR2(25)
CONSTRAINT member_last_name_nn NOT NULL,
first_name VARCHAR2(25),
address VARCHAR2(100),
city VARCHAR2(30),
phone VARCHAR2(15), s a
join_date DATE DEFAULT SYSDATE
) ha
CONSTRAINT member_join_date_nn NOT NULL);
l ฺ c om
b) Nombre de la tabla: TITLE
t m ai eฺ
CREATE TABLE title @ ho Guid
(title_id NUMBER(10)
8 4 4 ent
r 0 StuKEY,
CONSTRAINT title_title_id_pkdPRIMARY
title VARCHAR2(60)ha
d
CONSTRAINT title_title_nn is
(ric eNOTthNULL,
description z
ire to us
VARCHAR2(400)
a m
CONSTRAINT title_description_nn
e NOT NULL,
rating R ns
z title_rating_ck
VARCHAR2(4)
p e
CONSTRAINT
o lIN i c e
l('G', CHECK
L
(rating e
o rab VARCHAR2(20) 'PG', 'R', 'NC17', 'NR')),
a r dcategory
R s fe
ic nCONSTRAINT title_category_ck CHECK
o n - r a
t 'CHILD', 'SCIFI',
(category IN ('DRAMA', 'COMEDY', 'ACTION',
i c s o n 'DOCUMENTARY')),
Ed n release_date DATE);

c) Nombre de la tabla: TITLE_COPY


CREATE TABLE title_copy
(copy_id NUMBER(10),
title_id NUMBER(10)
CONSTRAINT title_copy_title_if_fk REFERENCES
title(title_id),
status VARCHAR2(15)
CONSTRAINT title_copy_status_nn NOT NULL
CONSTRAINT title_copy_status_ck CHECK (status IN
('AVAILABLE', 'DESTROYED','RENTED', 'RESERVED')),
CONSTRAINT title_copy_copy_id_title_id_pk
PRIMARY KEY (copy_id, title_id));

Oracle Database: Conceptos Fundamentales de SQL I AP-27


Soluciones a la Práctica 2-1 (continuación)
d) Nombre de la tabla: RENTAL
CREATE TABLE rental
(book_date DATE DEFAULT SYSDATE,
member_id NUMBER(10)
CONSTRAINT rental_member_id_fk REFERENCES
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

member(member_id),
copy_id NUMBER(10),
act_ret_date DATE,
exp_ret_date DATE DEFAULT SYSDATE + 2,
title_id NUMBER(10),
CONSTRAINT rental_book_date_copy_title_pk
PRIMARY KEY (book_date, member_id, copy_id,title_id),
CONSTRAINT rental_copy_id_title_id_fk
FOREIGN KEY (copy_id, title_id) s a
REFERENCES title_copy(copy_id, title_id)); ) ha
e) Nombre de la tabla: RESERVATION l ฺ c om
t m ai eฺ
CREATE TABLE reservation
(res_date DATE, @ ho Guid
member_id NUMBER(10) 8 4 4 ent
CONSTRAINT reservation_member_id
a r d0 REFERENCES
S t ud
member(member_id),
title_id ( r
NUMBER(10) ich this
i r ez use REFERENCES
CONSTRAINT reservation_title_id
title(title_id), a m e to
CONSTRAINT R ns title_id));
z reservation_resdate_mem_tit_pk PRIMARY KEY
p e c e
Lo ble li
(res_date, member_id,
o
dei ardqueslas
2) Verifique
c
conexiones f
de
a se han creado correctamente comprobando en el navegador
ertablas
SQL Developer.
n R ran
i c so a)onEn-tel navegador de conexiones, amplíe Connections > myconnection > Tables.
Ed n
3) Cree secuencias para identificar de forma única cada fila de las tablas MEMBER y
TITLE.
a) Número de miembro para la tabla MEMBER: empezar por 101; no permitir
almacenamiento en caché de los valores. Asigne el nombre MEMBER_ID_SEQ a la
secuencia.
CREATE SEQUENCE member_id_seq
START WITH 101
NOCACHE;

b) Número de título para la tabla TITLE: empezar por 92; no permitir


almacenamiento en caché de los valores. Asigne el nombre TITLE_ID_SEQ a la
secuencia.
CREATE SEQUENCE title_id_seq
START WITH 92
NOCACHE;

Oracle Database: Conceptos Fundamentales de SQL I AP-28


Soluciones a la Práctica 2-1 (continuación)
c) Verifique la existencia de las secuencias en el navegador de conexiones de SQL
Developer.
i) En el navegador de conexiones, asumiendo que el nodo myconnection está
ampliado, amplíe Sequences.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

4) Agregue datos a las tablas. Cree un script para cada juego de datos que desee agregar.
a) Agregue los títulos de las películas a la tabla TITLE. Escriba un script para
introducir la información sobre las películas. Guarde las sentencias en un script
denominado lab_apcs_4a.sql. Utilice las secuencias para identificar de forma
única cada título. Introduzca las fechas de versión en formato DD-MES-AAAA.
Recuerde que las comillas simples se deben gestionar de forma especial en los
campos de caracteres. Verifique las adiciones.
s a
INSERT INTO title(title_id, title, description, rating,
) ha
l ฺ om
category, release_date)
c
VALUES (title_id_seq.NEXTVAL, 'Willie and Christmas Too',
t m ai eฺ
'All of Willie''s friends make a Christmas list for

@ ho Guid
Santa, but Willie has yet to add his own wish list.',
'G', 'CHILD', TO_DATE('05-OCT-1995','DD-MON-YYYY'))
/ 8 4 4 ent
r d0 Stud
INSERT INTO title(title_id , title, description, rating,
a
( r
VALUES
ich this category, release_date)
(title_id_seq.NEXTVAL, 'Alien Again', 'Yet another
i r ez use installment of science fiction history. Can the
R am se to heroine save the planet from the alien life form?',

o p ez licen /
'R', 'SCIFI', TO_DATE( '19-MAY-1995','DD-MON-YYYY'))

r d o L rable INSERT INTO title(title_id, title, description, rating,

R ica nsfe VALUES


category, release_date)
(title_id_seq.NEXTVAL, 'The Glob', 'A meteor crashes

c s on n-tra near a small American town and unleashes carnivorous


i no
Ed
goo in this classic.', 'NR', 'SCIFI',
TO_DATE( '12-AUG-1995','DD-MON-YYYY'))
/
INSERT INTO title(title_id, title, description, rating,
category, release_date)
VALUES (title_id_seq.NEXTVAL, 'My Day Off', 'With a little
luck and a lot ingenuity, a teenager skips school
for
a day in New York.', 'PG', 'COMEDY',
TO_DATE( '12-JUL-1995','DD-MON-YYYY'))
/
INSERT INTO title(title_id, title, description, rating,
category, release_date)
VALUES (title_id_seq.NEXTVAL, 'Miracles on Ice', 'A six-
year-old has doubts about Santa Claus, but she discovers
that miracles really do exist.', 'PG', 'DRAMA',
TO_DATE('12-SEP-1995','DD-MON-YYYY'))
/

Oracle Database: Conceptos Fundamentales de SQL I AP-29


Soluciones a la Práctica 2-1 (continuación)

INSERT INTO title(title_id, title, description, rating,


category, release_date)
VALUES (title_id_seq.NEXTVAL, 'Soda Gang', 'After
discovering a cache of drugs, a young couple find themselves
pitted against a vicious gang.', 'NR', 'ACTION', TO_DATE('01-
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

JUN-1995','DD-MON-YYYY'))
/
COMMIT
/
SELECT title
FROM title;

b) Agregue datos a la tabla MEMBER. Inserte las sentencias en un script denominado s a


lab_apcs_4b.sql. Ejecute los comandos del script. Asegúrese de utilizar la ) ha
ฺ c
secuencia para agregar los números de miembro.
l om
SET VERIFY OFF t m ai eฺ
INSERT INTO member(member_id, first_name, last_name,
@ ho Guid
address, city, phone, join_date)
8 4 4 ent
VALUES (member_id_seq.NEXTVAL, 'Carmen',
r 0 'Velasquez',
t ud
d'206-899-6666',
a S
ich this
'283 King Street', 'Seattle',
TO_DATE('08-MAR-1990', ( r
z use
'DD-MM-YYYY'))
i r e
/
R am se to
p ez licen
INSERT INTO member(member_id,
o first_name, last_name,
o L ble
address, city, phone, join_date)
VALUES
c a rd '5 fModrany',
e r a
(member_id_seq.NEXTVAL, 'LaDoris', 'Ngao',
R i n s 'Bratislava', '586-355-8882',
n r a
so on-t 'DD-MM-YYYY'))
TO_DATE('08-MAR-1990',
i c
Ed n/
INSERT INTO member(member_id, first_name, last_name,
address, city, phone, join_date)
VALUES (member_id_seq.NEXTVAL, 'Midori', 'Nagayama',
'68 Via Centrale', 'Sao Paolo', '254-852-5764',
TO_DATE('17-JUN-1991',
'DD-MM-YYYY'))
/

INSERT INTO member(member_id, first_name, last_name,


address, city, phone, join_date)
VALUES (member_id_seq.NEXTVAL, 'Mark', 'Quick-to-See',
'6921 King Way', 'Lagos', '63-559-7777', TO_DATE('07-
APR-1990',
'DD-MM-YYYY'))
/

Oracle Database: Conceptos Fundamentales de SQL I AP-30


Soluciones a la Práctica 2-1 (continuación)

INSERT INTO member(member_id, first_name, last_name,


address, city, phone, join_date)
VALUES (member_id_seq.NEXTVAL, 'Audry', 'Ropeburn',
'86 Chu Street', 'Hong Kong', '41-559-87',
TO_DATE('18-JAN-1991',
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

'DD-MM-YYYY'))
/

INSERT INTO member(member_id, first_name, last_name,


address, city, phone, join_date)
VALUES (member_id_seq.NEXTVAL, 'Molly', 'Urguhart',
'3035 Laurier', 'Quebec', '418-542-9988', TO_DATE('18-
JAN-1991',
'DD-MM-YYYY')); s a
/
) ha
l ฺ c om
COMMIT
SET VERIFY ON t m ai eฺ
@
c) Agregue las siguientes copias de películas a la tabla TITLE_COPY
ho : Guid
8 4 4 ent
Nota: tenga a mano los números de TITLE_IDdpara
r 0 este tejercicio.
ud
a S
h his status)
INSERT INTO title_copy(copy_id,
( r ictitle_id,
t
VALUES (1, 92, 'AVAILABLE')z s e
r e u
/
a mi e to title_id,
VALUES (1, 93, e z R
INSERT INTO title_copy(copy_id,
n s status)

o p 'AVAILABLE')
l i c e
o L title_copy(copy_id,
le
/
INSERTdINTO
r r a b title_id, status)
i c
VALUESa (2,
s f e
93, 'RENTED')
n R
/
r a n
i c so INSERT
o n -t INTO title_copy(copy_id, title_id, status)
Ed nVALUES (1, 94, 'AVAILABLE')
/
INSERT INTO title_copy(copy_id, title_id, status)
VALUES (1, 95, 'AVAILABLE')
/
INSERT INTO title_copy(copy_id, title_id,status)
VALUES (2, 95, 'AVAILABLE')
/
INSERT INTO title_copy(copy_id, title_id,status)
VALUES (3, 95, 'RENTED')
/
INSERT INTO title_copy(copy_id, title_id,status)
VALUES (1, 96, 'AVAILABLE')
/
INSERT INTO title_copy(copy_id, title_id,status)
VALUES (1, 97, 'AVAILABLE')
/

Oracle Database: Conceptos Fundamentales de SQL I AP-31


Soluciones a la Práctica 2-1 (continuación)
d) Agregue los siguientes alquileres a la tabla RENTAL:
Nota: el número de título puede ser diferente en función del número de secuencia.
INSERT INTO rental(title_id, copy_id, member_id,
book_date, exp_ret_date, act_ret_date)
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

VALUES (92, 1, 101, sysdate-3, sysdate-1, sysdate-2)


/
INSERT INTO rental(title_id, copy_id, member_id,
book_date, exp_ret_date, act_ret_date)
VALUES (93, 2, 101, sysdate-1, sysdate-1, NULL)
/
INSERT INTO rental(title_id, copy_id, member_id,
book_date, exp_ret_date, act_ret_date)
VALUES (95, 3, 102, sysdate-2, sysdate, NULL)
s a
/
) ha
INSERT INTO rental(title_id, copy_id, member_id,
book_date, exp_ret_date,act_ret_date) l ฺ c om
VALUES (97, 1, 106, sysdate-4, sysdate-2, sysdate-2)
t m ai eฺ
/
COMMIT @ ho Guid
/ 8 4 4 ent
5) Cree una vista con el nombre TITLE_AVAIL h a
para
d0 Slostutítulos
rmostrar d
de las películas,
la disponibilidad de cada copia y la fecha r i c h i s
t esperada si está alquilada.
( de devolución
r e z
i to u
Consulte todas las filas de la vista. Ordene los s e
resultados por título.
m
Nota: los resultados pueden
z Raser diferentes.
n se
p e e
lic AS
otitle_avail
CREATE VIEW L l e
SELECT
a r do t.title,
r a b c.copy_id, c.status, r.exp_ret_date
e t JOIN title_copy c
R c nsft.title_id
FROM
iON title

o n FULL - t r aOUTER JOIN rental = c.title_id


s
ic noON n r
Ed c.copy_id = r.copy_id
AND c.title_id = r.title_id;

SELECT *
FROM title_avail
ORDER BY title, copy_id;

Oracle Database: Conceptos Fundamentales de SQL I AP-32


Soluciones a la Práctica 2-1 (continuación)
6) Realice cambios en los datos de las tablas.
a) Agregue un nuevo título. La película es “Interstellar Wars”, que tiene la categoría
PG y está clasificada como una película de ciencia ficción. La fecha de la versión
es 07-JUL-77. La descripción es “Futuristic interstellar action movie. Can the
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

rebels save the humans from the evil empire?” Asegúrese de agregar un registro
de copia de título para dos copias.
INSERT INTO title(title_id, title, description, rating,
category, release_date)
VALUES (title_id_seq.NEXTVAL, 'Interstellar Wars',
'Futuristic interstellar action movie. Can the
rebels save the humans from the evil empire?',
'PG', 'SCIFI', '07-JUL-77')
/ s a
INSERT INTO title_copy (copy_id, title_id, status) ) ha
VALUES (1, 98, 'AVAILABLE')
l ฺ c om
/
t m
INSERT INTO title_copy (copy_id, title_id, status)
ai eฺ
VALUES (2, 98, 'AVAILABLE')
@ ho Guid
/
8 4 4 ent
r d0 Velasquez,
b) Introduzca dos reservas. Una reserva es paraaCarmen
S t ud que desea
ch MarkthQuick-to-See,
alquilar “Interstellar Wars”. La otra esripara
( is que desea
alquilar “Soda Gang”. z
re o us
i(res_date, e
m
INSERT INTO reservation
VALUES (SYSDATE,z101, Ra 98)nse t member_id, title_id)

/ o p e lice
INSERT INTO o L reservation
b le (res_date, member_id, title_id)
a r d r a
VALUES
/ ic
R n s fe
(SYSDATE, 104, 97)

o7)n Realice
- a
truna
i c s o n modificación en una de las tablas.
Ed n
a) Ejecute el script lab_apcs_7a.sql ubicado en la carpeta
/home/oracle/labs/sql1/labs, para agregar una columna PRICE a la tabla
TITLE para registrar el precio de venta del vídeo. Verifique las modificaciones.
ALTER TABLE title
ADD (price NUMBER(8,2));

DESCRIBE title

Oracle Database: Conceptos Fundamentales de SQL I AP-33


Soluciones a la Práctica 2-1 (continuación)
b) Cree un script con el nombre lab_apcs_7b.sql que contenga sentencias de
actualización para actualizar cada vídeo con un precio según la lista
proporcionada. Ejecute los comandos del script.
Nota: tenga a mano los números de TITLE_ID para este ejercicio.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SET ECHO OFF


SET VERIFY OFF
UPDATE title
SET price = &price
WHERE title_id = &title_id;
SET VERIFY OFF
SET ECHO OFF

8) Cree un informe que contenga el historial de alquiler de vídeos de cada cliente.


s a
) ha
Asegúrese de incluir el nombre del cliente, la película alquilada, las fechas de alquiler

l ฺ c om
y la duración de los alquileres. Calcule el número total de alquileres de todos los

en un script lab_apcs_8.sql. t m ai eฺ
clientes para el período de informe. Guarde los comandos generados por el informe

Nota: los resultados pueden ser diferentes. @ ho Guid


8 4 4 ent
SELECT m.first_name||' '||m.last_name
r 0MEMBER,
t udt.title,
dr.book_date
r.book_date, r.act_ret_date
c a
h his
- S DURATION
FROM member m ( r i t
JOIN rental r r e z s e
ON a mi e to u
r.member_id = m.member_id
JOIN title t z R ns
ON r.title_id
o p e i c e
= t.title_id
l
r d o L rable
ORDER BY member;

R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I AP-34


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Descripciones de las Tablas

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Descripción de Esquema
Descripción General
Los esquemas de ejemplo de Oracle Database ilustran una compañía de ejemplo que opera en todo el
mundo para surtir pedidos de varios productos distintos. La compañía tiene tres divisiones:
• Human Resources: realiza un seguimiento de la información sobre los empleados y las
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

instalaciones.
• Order Entry: realiza un seguimiento de los inventarios y las ventas de productos a través de
distintos canales.
• Sales History: realiza un seguimiento de los datos estadísticos de negocio para facilitar las
decisiones de negocio.
Cada una de estas divisiones se representa mediante un esquema. En este curso tendrá acceso a los
objetos de todos los esquemas. No obstante, el énfasis de los ejemplos, demostraciones y prácticas
está en el esquema de Human Resources (HR).
s a
Todos los scripts necesarios para crear los esquemas de ejemplo están en la carpeta ) ha
$ORACLE_HOME/demo/schema/.
l ฺ c om
Human Resources (HR)
t m ai eฺ
ho Guid
Se trata del esquema que se utiliza en este curso. En los registros de recursos humanos (HR), cada
@
4 4 ent
empleado tiene un número de identificación, una dirección de correo electrónico, un código de
8
a r d0 Stud
identificación de cargo, un salario y un gestor. Algunos empleados ganan comisiones además de su
salario.
( r ich this
i r ez use
La compañía también registra información sobre cargos dentro de la organización. Cada cargo

R am se to
dispone de un código de identificación, un puesto y un rango de salario máximo y mínimo para el
cargo. Algunos empleados llevan bastante tiempo en la compañía y han desempeñado distintos
o p ez licentrabajos en ella. Cuando se reasigna un empleado, se registran la duración del trabajo del empleado,

r d o L rable el número de identificación del cargo y el departamento.

R ica nsfe La compañía de ejemplo se extiende por distintas regiones, por lo que registra la ubicación de sus

c s on n-tra almacenes y departamentos. Cada empleado está asignado a un departamento y cada departamento se
i no identifica mediante un número de departamento único o una abreviatura. Cada departamento está
Ed asociado a una ubicación y cada ubicación tiene una dirección completa que incluye el nombre de la
calle, el código postal, la ciudad, el estado o la provincia y el código de país.
En las ubicaciones de los departamentos y almacenes, la compañía registra detalles como el nombre
de país, el símbolo y nombre de divisa y la región en la que está ubicado geográficamente el país.

Oracle Database: Conceptos Fundamentales de SQL I B-2


Diagrama de Relación de Entidades de HR

HR DEPARTMENTS
department_id
LOCATIONS
location_id
department_name street_address
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

manager_id postal_code
location_id city
state_province
country_id
JOB_HISTORY
employee_id
start_date EMPLOYEES
end_date employee_id
job_id first_name
COUNTRIES a
department_id last_name
s
) ha
country_id
email
country_name

ฺ c om
phone_number
hire_date
l
region_id

t m ai eฺ
job_id
JOBS
job_id
@ ho Guid salary
commission_pct
job_title
8 4 4 eREGIONS
n t manager_id
min_salary
max_salary a r d0 Stud region_id
department_id

( r ich this region_name

i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I B-3


Descripciones de las Tablas de Human Resources (HR)
DESCRIBE countries
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT * FROM countries;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I B-4


Descripciones de las Tablas de Human Resources (HR) (continuación)
DESCRIBE departments
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT * FROM departments;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I B-5


Descripciones de las Tablas de Human Resources (HR) (continuación)
DESCRIBE employees
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
SELECT * FROM employees; @ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I B-6


Descripciones de las Tablas de Human Resources (HR) (continuación)
DESCRIBE job_history
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT * FROM job_history

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I B-7


Descripciones de las Tablas de Human Resources (HR) (continuación)
DESCRIBE jobs
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT * FROM jobs

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I B-8


Descripciones de las Tablas de Human Resources (HR) (continuación)
DESCRIBE locations
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT * FROM locations


s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I B-9


Descripciones de las Tablas de Human Resources (HR) (continuación)
DESCRIBE regions
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT * FROM regions

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I B-10


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Uso de SQL Developer


s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Objetivos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Al finalizar este apéndice, debería estar capacitado para lo


siguiente:
• Mostrar las funciones clave de Oracle SQL Developer
• Identificar las opciones de menú de Oracle SQL Developer
• Crear una conexión a la base de datos
• Gestionar objetos de bases de datos a
• Utilizar la hoja de trabajo de SQL ) has
o m
• Guardar y ejecutar scripts SQL a ilฺc ฺ
m
• Crear y guardar informes hot uide
8 4 4@ ent G
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Objetivos ica s fe
R n
Ens n - trase ofrece una introducción a la herramienta gráfica SQL Developer. Aprenderá
n apéndice,
oeste
i c no SQL Developer para las tareas de desarrollo de la base de datos. Aprenderá cómo
Ed cómo utilizar utilizar la hoja de trabajo de SQL para ejecutar sentencias y scripts SQL.

Oracle Database: Conceptos Fundamentales de SQL I C-2


¿Qué es Oracle SQL Developer?
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Oracle SQL Developer es una herramienta gráfica que


mejora la productividad y simplifica las tareas de
desarrollo de la base de datos.
• Puede conectarse a cualquier esquema de Oracle
Database de destino mediante la autenticación estándar
de Oracle Database.
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
r
SQL
i ezDeveloper u se
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
¿Qué es Oracle
R icaSQLnsDeveloper?
fe
Oracle
s n tra es una herramienta gráfica gratuita diseñada para mejorar la productividad y
onSQL Developer
-
i c oel desarrollo de las tareas diarias de la base de datos. Con sólo unos clics, puede crear y
Edsimplificar
n
depurar fácilmente los procedimientos almacenados, probar sentencias SQL y visualizar los planes del
optimizador.
SQL Developer, la herramienta visual para el desarrollo de la base de datos, simplifica las siguientes
tareas:
• Examen y gestión de objetos de la base de datos
• Ejecución de sentencias y scripts SQL
• Edición y depuración de sentencias PL/SQL
• Creación de informes
Puede conectarse a cualquier esquema de Oracle Database de destino mediante la autenticación estándar
de Oracle Database. Una vez conectado, puede realizar operaciones en los objetos de la base de datos.
SQL Developer versión 1.2 está estrechamente integrado con Developer Migration Workbench, que
proporciona a los usuarios un punto único para examinar los objetos y datos de base de datos en bases
de datos de terceros y migrar desde estas bases de datos a Oracle. También se puede conectar a los
esquemas para las bases de datos de terceros (no de Oracle) seleccionadas, como MySQL, Microsoft
SQL Server y Microsoft Access, y ver los metadatos y datos de estas bases de datos.
Además, SQL Developer incluye soporte para Oracle Application Express 3.0.1 (Oracle APEX).

Oracle Database: Conceptos Fundamentales de SQL I C-3


Especificaciones de SQL Developer
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Incluido con Oracle Database 11g Versión 2


• Desarrollado en Java
• Soporta plataformas Windows, Linux y Mac OS X
• Permite la conectividad por defecto mediante el
controlador JDBC Thin
• Se conecta a Oracle Database versión 9.2.0.1 y s a
posteriores m ) ha
l ฺ c o
• Descarga gratuita desde el siguiente enlace:
t m ai eฺ
– http://www.oracle.com/technology/products/database/
@ ho Guid
sql_developer/index.html
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica de
Especificaciones
R n s fe Developer
SQL
Oracle
s - tra 1.5 se incluye con Oracle Database 11g Versión 2. SQL Developer está
onSQLnDeveloper
i c no en Java aprovechando el entorno de desarrollo integrado (IDE) de Oracle JDeveloper.
Ed desarrollado
Por lo tanto, es una herramienta entre plataformas. La herramienta se ejecuta en plataformas
Windows, Linux y Mac OS (sistema operativo) X.
La conectividad por defecto a la base de datos se realiza a través del controlador Java Database
Connectivity (JDBC) Thin y, por lo tanto, no es necesario el directorio raíz de Oracle. SQL
Developer no necesita un instalador y simplemente necesita descomprimir los archivos descargados.
Con SQL Developer, los usuarios se pueden conectar a Oracle Databases 9.2.0.1 y versiones
posteriores y a todas las ediciones de Oracle Database, incluida Express Edition.
Nota
Para versiones de Oracle Database anteriores a Oracle Database 11g Versión 2, tendrá que descargar
e instalar SQL Developer. SQL Developer 1.5 se puede descargar gratuitamente desde el siguiente
enlace:
http://www.oracle.com/technology/products/database/sql_developer/index.html.
Para obtener más instrucciones sobre cómo instalar SQL Developer, consulte el sitio web en:
http://download.oracle.com/docs/cd/E12151_01/index.htm

Oracle Database: Conceptos Fundamentales de SQL I C-4


Interfaz de SQL Developer 1.5
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Debe definir una


conexión para empezar s a
a utilizar SQL Developer ) ha
para la ejecución de l ฺ c om
consultas SQL en un
t m ai eฺ
esquema de base de
@ ho Guid
datos.
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
R ca Developer
Interfaz de iSQL
n s fe 1.5
La o
s n de-SQL
interfaz
n tra Developer 1.5 contiene tres separadores de navegación principales, de izquierda a
i c no
Ed derecha:
• Separador Connections: si utiliza este separador, puede examinar los objetos y usuarios de la
base de datos a los que tiene acceso.
• Separador Files: identificado mediante el icono de carpeta Files, este separador permite
acceder a los archivos desde la máquina local sin tener que utilizar el menú File > Open.
• Separador Reports: identificado mediante el icono Reports, este separador permite ejecutar
los informes predefinidos o crear y aplicar sus propios informes.
Navegación General y Uso
SQL Developer utiliza la parte izquierda de la navegación para buscar y seleccionar objetos y la parte
derecha para mostrar información sobre los objetos seleccionados. También puede personalizar
muchos aspectos de la apariencia y del comportamiento de SQL Developer mediante la definición de
preferencias.
Nota: debe definir al menos una conexión para conectarse a un esquema de base de datos y emitir
consultas SQL o ejecutar procedimientos/funciones.

Oracle Database: Conceptos Fundamentales de SQL I C-5


Interfaz de SQL Developer 1.5 (continuación)
Menús
Los siguientes menús contienen entradas estándar, además de entradas de funciones especificas de
SQL Developer.
• View: contiene opciones que afectan a lo que se muestra en la interfaz de SQL Developer.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Navigate: contiene opciones para acceder a los paneles y ejecutar los subprogramas.
• Run: contiene las opciones Run File y Execution Profile, que son relevantes en la selección de
una función o un procedimiento, además de las opciones de depuración.
• Source: contiene opciones para utilizarlas al editar funciones y procedimientos.
• Versioning: proporciona soporte integrado para los siguientes sistemas de control de versiones
y orígenes: CVS (Concurrent Versions System) y Subversion.
• Migration: contiene opciones relacionadas con la migración de bases de datos de terceros a
Oracle.
s a
• Tools: llama a las herramientas de SQL Developer, como SQL*Plus, Preferences y SQL
) ha
Worksheet.
l ฺ c om
t m ai eฺ
Nota: el menú Run también contiene opciones relevantes para la selección de una función o un

versión 1.2. @ ho Guid


procedimiento para depuración. Son las mismas opciones que las del menú Debug de la

8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I C-6


Creación de una Conexión a la Base Datos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Debe tener al menos una conexión a la base de datos


para utilizar SQL Developer.
• Puede crear y probar conexiones para:
– Varias bases de datos
– Varios esquemas
• SQL Developer importa automáticamente las conexiones a
s
definidas en el archivo tnsnames.ora al sistema.
m ) ha
• Puede exportar conexiones a un archivo Extensible ilฺco
Markup Language (XML). t m a eฺ
@ ho Guid
• Cada conexión a la base de datos adicional
4 4 creada
n t se
8 e
rd0 detconexiones.
muestra en la jerarquía del navegador
ha his S
ud
( r i c t
r e z s e
a mi e to u
z R ns
o p e
Copyright
l i c e y/o sus filiales. Todos los derechos reservados.
© 2010, Oracle

r d o L rable
Creación de a Conexión
icuna s fe a la Base Datos
R n
Una
s n
oconexión
n - traun objeto de SQL Developer que especifica la información necesaria para
es
i c noa una base de datos concreta como usuario específico de dicha base de datos. Para utilizar
Ed conectarse
SQL Developer, debe tener al menos una conexión a la base de datos que puede ser existente, creada
o importada.
Puede crear y probar conexiones para varias bases de datos y esquemas.
Por defecto, el archivo tnsnames.ora está ubicado en el directorio
$ORACLE_HOME/network/admin, pero también puede estar en el directorio especificado por la
variable de entorno TNS_ADMIN o el valor de registro. Al iniciar SQL Developer, cuando se muestra
el cuadro de diálogo Database Connections, SQL Developer importa automáticamente las conexiones
definidas en el archivo tnsnames.ora al sistema.
Nota: en los sistemas Windows, si existe el archivo tnsnames.ora, pero SQL Developer no está
utilizando sus conexiones, defina TNS_ADMIN como una variable de entorno del sistema.
Puede exportar conexiones a un archivo XML para poder volver a utilizarlas.
Puede crear conexiones adicionales como usuarios diferentes a la misma base de datos o conectarse a
diferentes bases de datos.

Oracle Database: Conceptos Fundamentales de SQL I C-7


Creación de una Conexión a la Base Datos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

1 2

3 a
s
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Creación de a Conexión
icuna s fe a la Base Datos (continuación)
R n
ra a la base de datos, realice los siguientes pasos:
n una-tconexión
Para
c s ocrear n
i opágina con separadores Connections, haga clic con el botón derecho del mouse en
Ed 1. Connections
Ennla
y seleccione New Connection.
2. En la ventana New/Select Database Connection, introduzca el nombre de la conexión.
Introduzca el nombre de usuario y la contraseña del esquema al que desea conectarse.
a) En la lista desplegable Role, puede seleccionar default o SYSDBA. (Debe seleccionar
SYSDBA para el usuario sys o cualquier usuario con privilegios de administrador de la
base de datos).
b) Puede seleccionar el tipo de conexión como:
Basic: en este tipo, introduzca el nombre del host y el SID de la base de datos a la que
desea conectarse. El puerto ya está definido en 1521. También puede introducir el
nombre del servicio directamente si utiliza una conexión a la base de datos remota.
TNS: puede seleccionar cualquiera de los alias de base de datos importados del archivo
tnsnames.ora.
LDAP: puede consultar los servicios de base de datos en Oracle Internet Directory, que
es un componente de Oracle Identity Management.
Advanced: puede definir una URL de Java Database Connectivity (JDBC) URL
personalizada para conectarse a la base de datos.

Oracle Database: Conceptos Fundamentales de SQL I C-8


Creación de una Conexión a la Base Datos (continuación)
c) Haga clic en Test para asegurarse de que la conexión se ha definido correctamente.
d) Haga clic en Connect.
Si activa la casilla de control Save Password, la contraseña se guarda en un archivo XML. De
este modo, cuando cierre la conexión a SQL Developer y la vuelva a abrir, no se le pedirá la
contraseña.
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

3. La conexión se agrega al navegador de conexiones. Puede ampliar la conexión para ver los
objetos de base de datos y las definiciones de objetos (por ejemplo, dependencias, detalles,
estadísticas, etc.).
Nota: en la misma ventana New/Select Database Connection, puede definir conexiones a orígenes de
datos no Oracle mediante los separadores Access, MySQL y SQL Server. Sin embargo, se trata de
conexiones de sólo lectura que permiten examinar los objetos y datos de dicho origen de datos.
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I C-9


Examen de Objetos de Bases de Datos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Utilizar el navegador de conexiones para:


• Examinar los objetos de un esquema de base de datos
• Revisar las definiciones de objetos de forma rápida

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Examen deic a sdefeBases de Datos
Objetos
R n
n creada-trlaaconexión
Unaovez a la base de datos, puede utilizar el navegador de conexiones para
i c s o n
Ed paquetes,n procedimientos, disparadores
examinar los objetos de un esquema de base de datos entre los que se incluyen tablas, vistas, índices,
y tipos.
SQL Developer utiliza la parte izquierda de la navegación para buscar y seleccionar objetos y la parte
derecha para mostrar la información sobre los objetos seleccionados. También puede personalizar
muchos aspectos de la apariencia de SQL Developer mediante la definición de preferencias.
Puede ver la definición de los objetos desglosados en separadores de información que se transfieren
al diccionario de datos. Por ejemplo, si selecciona una tabla en el navegador, se muestran los detalles
sobre las columnas, restricciones, permisos, estadísticas, disparadores, etc., en una página con
separadores fáciles de leer.
Si desea ver la definición de la tabla EMPLOYEES como se muestra en la diapositiva, realice los
siguientes pasos:
1. Amplíe el nodo Connections en el navegador de conexiones.
2. Amplíe Tables.
3. Haga clic en EMPLOYEES. Por defecto, está seleccionado el separador Columns. Se muestra la
descripción de las columnas de la tabla. Mediante el separador Data, puede ver los datos de la
tabla e introducir las nuevas filas, datos de actualización y confirmar estos cambios en la base
de datos.

Oracle Database: Conceptos Fundamentales de SQL I C-10


Visualización de la Estructura de la Tabla

Utilizar el comando DESCRIBE para mostrar la estructura de


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

una tabla:

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Visualización
R icade lanEstructura
s fe de la Tabla
n r a
-t también puede visualizar la estructura de una tabla mediante el comando
i
En
c soSQL Developer,
o n
Ed dato, asíncomo una
DESCRIBE. El resultado del comando es una visualización de los nombres de columna y tipos de
indicación de si una columna debe contener datos.

Oracle Database: Conceptos Fundamentales de SQL I C-11


Examen de Archivos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Utilizar el navegador de archivos para explorar el sistema de


archivos y abrir archivos del sistema.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Examen deic a sdefeBases de Datos
Objetos
R an
nutilizar-eltrnavegador
c s o
Puede
n de archivos para examinar y abrir archivos del sistema.
i o
Ed •• Para n ver el navegador de archivos, haga clic en el separador Files o seleccione View > Files.
Para
ver el contenido de un archivo, haga clic dos veces en un nombre de archivo para mostrar
su contenido en el área de la hoja de trabajo de SQL.

Oracle Database: Conceptos Fundamentales de SQL I C-12


Creación de un Objeto de Esquema

• SQL Developer soporta la creación de cualquier objeto de


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

esquema mediante:
– Ejecución de una sentencia SQL en SQL Worksheet
– Uso del menú contextual
• Editar los objetos mediante un cuadro de diálogo de edición
o con uno de los muchos menús sensibles al contexto.
a
• Ver el lenguaje de definición de datos (DDL) para los
) has
ajustes, como la creación de un nuevo objeto o la edición
l ฺ c omde
i ฺ
un objeto de esquema existente. maot uide
h
8 4 4@ ent G
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Creación de a Objeto
icun s fede Esquema
R n
a la creación de cualquier objeto de esquema mediante la ejecución de una
SQL
c s onDeveloper
n - trsoporta
i noSQL en la hoja de trabajo de SQL. Por otro lado, puede crear objetos mediante los menús
Ed sentencia
contextuales. Cuando se crea, puede editar los objetos con un cuadro de diálogo de edición o con uno
de los muchos menús sensibles al contexto.
Una vez que se han creado los nuevos objetos o se han editado los existentes, el DDL de estos ajustes
estará disponible para la revisión. Una opción Export DDL está disponible si desea crear el DDL
completo para uno o más objetos en el esquema.
La diapositiva muestra cómo crear una tabla mediante el menú contextual. Para abrir un cuadro de
diálogo para la creación de una nueva tabla, haga clic con el botón derecho del mouse en Tables y
seleccione New Table. Los cuadros de diálogo para la creación y edición de objetos de la base de
datos tienen varios separadores, cada uno de ellos contiene un agrupamiento lógico de propiedades
para dicho tipo de objeto.

Oracle Database: Conceptos Fundamentales de SQL I C-13


Creación de una Nueva Tabla: Ejemplo
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Creación de a Nueva
icuna s feTabla: Ejemplo
R n
a Create Table, si no activa la casilla de control Advanced, puede crear una
En
c s oelncuadronde-trdiálogo
i rápidamente
no
Ed tabla
frecuencia.
mediante la especificación de columnas y algunas funciones utilizadas con

Si activa la casilla de control Advanced, el cuadro de diálogo Create Table cambia a otro con varias
opciones, en las que puede especificar un juego ampliado de funciones mientras crea la tabla.
En el ejemplo de la diapositiva se muestra cómo crear la tabla DEPENDENTS mediante la activación
de la casilla de control Advanced.
Para crear una nueva tabla, realice los siguientes pasos:
1. En el navegador de conexiones, haga clic con el botón derecho del mouse en Tables.
2. Seleccione Create TABLE.
3. En el cuadro de diálogo Create Table, seleccione Advanced.
4. Especifique la información de columna.
5. Haga clic en OK.
Aunque no es necesario, también debe especificar una clave primaria con el separador Primary Key
en el cuadro de diálogo. En ocasiones, puede que desee editar la tabla que ha creado; para ello, haga
clic con el botón derecho del mouse en la tabla del navegador de conexiones y seleccione Edit.

Oracle Database: Conceptos Fundamentales de SQL I C-14


Uso de la Hoja de Trabajo de SQL

• Utilizar la hoja de trabajo de SQL para introducir y ejecutar


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

sentencias SQL, PL/SQL y SQL *Plus.


• Especificar las acciones que se pueden procesar mediante
la conexión a la base de datos asociada a la hoja de trabajo.

s a
) ha
l ฺ c om
t m ai eฺ
o Worksheet.
O hacer clic
h uid
en el icono
Seleccionar SQL Worksheet
4 @
Open
4 ent SQL
G
en el menú Tools. 8
d0 Stud
a r
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Uso de la Hoja
R ica de nTrabajo
s fe de SQL
Al n
oconectarse- a base de datos, automáticamente se abre una ventana de hoja de trabajo de SQL
atruna
i c s n
Ed para dichanoconexión. Puede utilizar la hoja de trabajo de SQL para introducir y ejecutar sentencias
SQL, PL/SQL y SQL *Plus. SQL Worksheet soporta sentencias SQL*Plus hasta un determinado
grado. Las sentencias SQL*Plus no soportadas por la hoja de trabajo de SQL se ignoran y no se
transfieren a la base de datos.
Puede especificar las acciones que se pueden procesar mediante la conexión a la base de datos
asociada a la hoja de trabajo, como:
• Creación de una tabla
• Inserción de datos
• Creación y edición de un disparador
• Selección de datos de tablas
• Guardado de datos seleccionados en un archivo
Para visualizar una hoja de trabajo de SQL, utilice una de las siguientes opciones:
• Seleccione Tools > SQL Worksheet.
• Haga clic en el icono Open SQL Worksheet.

Oracle Database: Conceptos Fundamentales de SQL I C-15


Uso de la Hoja de Trabajo de SQL
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

2 4 6 8

s a
1 3 5 7 9 ) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica de nTrabajo
Uso de la Hoja
R s fe de SQL (continuación)
onque desee
Puede - a teclas de acceso directo o iconos para realizar determinadas tareas como la
trutilizar
i c s n
ode una sentencia SQL o de un script y la visualización del historial de sentencias SQL
Ed ejecución
n
ejecutadas. Puede utilizar la barra de herramientas de la hoja de trabajo de SQL que contiene iconos
para realizar las siguientes tareas:
1. Execute Statement: ejecuta la sentencia en la que está ubicado el cursor del cuadro Enter SQL
Statement. Puede utilizar variables de enlace en las sentencias SQL pero no variables de
sustitución.
2. Run Script: ejecuta todas las sentencias en el cuadro Enter SQL Statement mediante Script
Runner. Puede utilizar variables de sustitución en las sentencias SQL pero no variables de
enlace.
3. Commit: escribe cualquier cambio realizado en la base de datos y finaliza la transacción.
4. Rollback: desecha cualquier cambio realizado en la base de datos, sin escribirlos en la base de
datos y finaliza la transacción.
5. Cancel: para la ejecución de cualquier sentencia que se esté ejecutando actualmente.
6. SQL History: muestra un recuadro de diálogo con información sobre las sentencias SQL
ejecutadas.
7. Execute Explain Plan: genera la ejecución del plan, que puede ver haciendo clic en el
separador Explain.
8. Autotrace: genera información de rastreo sobre la sentencia.
9. Clear: borra la sentencia o sentencias del recuadro Enter SQL Statement.

Oracle Database: Conceptos Fundamentales de SQL I C-16


Uso de la Hoja de Trabajo de SQL
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Introducir
sentencias SQL.

s a
) ha
l ฺ c om
Los resultados se
t m ai eฺmuestran aquí.
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Uso de la Hoja
R ica de nTrabajo
s fe de SQL (continuación)
Al n
oconectarse- a base de datos, automáticamente se abre una ventana de hoja de trabajo de SQL
atruna
i c s n
Ed para dichanoconexión. Puede utilizar la hoja de trabajo de SQL para introducir y ejecutar sentencias
SQL, PL/SQL y SQL *Plus. Todos los comandos SQL y PL/SQL están soportados conforme se
transfieren directamente desde la hoja de trabajo de SQL a Oracle Database. La hoja de trabajo de
SQL debe interpretar los comandos SQL*Plus utilizados en SQL Developer antes de transferirlos a la
base de datos.
La hoja de trabajo de SQL soporta actualmente varios comandos SQL*Plus. Los comandos que no
soporta la hoja de trabajo de SQL se ignoran y no se envían a Oracle Database. A través de la hoja de
trabajo de SQL, puede ejecutar sentencias SQL y algunos de los comandos SQL*Plus.
Puede mostrar una hoja de trabajo de SQL mediante cualquiera de las siguientes opciones:
• Seleccione Tools > SQL Worksheet.
• Haga clic en el icono Open SQL Worksheet.

Oracle Database: Conceptos Fundamentales de SQL I C-17


Ejecución de Sentencias SQL
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Uso del recuadro Enter SQL Statement para introducir una o


varias sentencias SQL.

F9 F5

s a
F5 ) ha m
l ฺ c o
F9
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Ejecución de
R icaSentencias
n s fe SQL
Ens oelnejemplo
n - trala diapositiva se muestra la diferencia entre la salida de la misma consulta cuando
de
i c o
Ed se utilizanla tecla [F9] o Execute Statement y cuando se utiliza [F5] o Run Script.

Oracle Database: Conceptos Fundamentales de SQL I C-18


Guardado de Scripts SQL
Hacer clic en el icono Save
1 para guardar la sentencia
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SQL en un archivo.

2
Identificar una ubicación,
s a
) ha
El contenido del archivo introducir un nombre de
3 archivo y hacer clic en Save.
om
guardado es visible y se
puede editar en la ventana
l ฺ c
de la hoja de trabajo de SQL.
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Guardado de
R icaScripts n s e
fSQL
onguardar
Puede
s n - tlasrasentencias SQL desde la hoja de trabajo de SQL en un archivo de texto. Para
i c o
Ed guardarnel contenido del cuadro Enter SQL Statement, realice los siguientes pasos:
1. Haga clic en el icono Save o utilice la opción de menú File > Save.
2. En el cuadro de diálogo Save, introduzca un nombre de archivo y la ubicación en la que desea
guardarlo.
3. Haga clic en Save.
Después de guardar el contenido de un archivo, en la ventana Enter SQL Statement se muestra una
página con separadores del contenido del archivo. Puede tener varios archivos abiertos al mismo
tiempo. Cada archivo se muestra como una página con separadores.
Script Pathing
Puede seleccionar una ruta de acceso por defecto para buscar y guardar scripts. En Tools >
Preferences > Database > Worksheet Parameters, introduzca un valor en el campo “Select default
path to look for scripts”.

Oracle Database: Conceptos Fundamentales de SQL I C-19


Ejecución de Archivos de Script Guardados:
Método 1
1. Utilizar el separador Files para buscar el
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

archivo de script que desea abrir.


2. Hacer clic dos veces en el script para mostrar
el código en la hoja de trabajo de SQL.
1

Para ejecutar el código, 2


hacer clic en: Seleccionar una
• Execute Script (F9) o 3 conexión de la lista
• Run Script (F5) desplegable.
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Ejecución de
R icaArchivos
n s fede Script Guardados: Método 1
Para
s n - tra de script y mostrar el código en el área de la hoja de trabajo de SQL, realice los
n un archivo
oabrir
i c nopasos:
Ed siguientes 1. En el navegador de archivos, seleccione (o navegue hasta) el archivo de script que desea abrir.
2. Haga clic dos veces para abrir. El código del archivo de script se muestra en el área de la hoja
de trabajo de SQL.
3. Seleccione una conexión de la lista desplegable de conexiones.
4. Para ejecutar el código, haga clic en el icono Run Script (F5) de la barra de herramientas de la
hoja de trabajo de SQL. Si no ha seleccionado una conexión de la lista desplegable de
conexiones, aparecerá un cuadro de diálogo de conexiones. Seleccione la conexión que desea
utilizar para la ejecución del script.
También puede realizar las siguientes acciones:
1. Seleccione File > Open. Aparece un cuadro de diálogo Open.
2. En el cuadro de diálogo Open, seleccione (o navegue hasta) el archivo de script que desea abrir.

Oracle Database: Conceptos Fundamentales de SQL I C-20


Ejecución de Archivos de Script Guardados: Método 1 (continuación)
3. Haga clic en Open. El código del archivo de script se muestra en el área de la hoja de trabajo de
SQL.
4. Seleccione una conexión de la lista desplegable de conexiones.
5. Para ejecutar el código, haga clic en el icono Run Script (F5) de la barra de herramientas de la
hoja de trabajo de SQL. Si no ha seleccionado una conexión de la lista desplegable de
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

conexiones, aparecerá un cuadro de diálogo de conexiones. Seleccione la conexión que desea


utilizar para la ejecución del script.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I C-21


Ejecución de Archivos de Script Guardados:
Método 2
Utilice el comando @
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

seguido de la ubicación y el
nombre del archivo que
desea ejecutar y haga clic
en el icono Run Script.

s a
) ha
La salida del script se
l ฺ c om
muestra en la página
con separadores Script
t m ai eฺ
Output.
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Ejecución de
R icaArchivos
n s fede Script Guardados: Método 2
Para n un
oguardar - a SQL, realice los siguientes pasos:
trscript
i c s n
no el comando @, seguido de la ubicación y el nombre del archivo que desea ejecutar en la
Ed 1. Utilice ventana Enter SQL Statement.
2. Haga clic en el icono Run Script.
El resultado de la ejecución del archivo se muestra en la página con separadores Script Output.
También puede guardar la salida del script haciendo clic en el icono Save de la página con
separadores Script Output. Aparece el cuadro de diálogo File Save donde puede identificar un
nombre y una ubicación para el archivo.

Oracle Database: Conceptos Fundamentales de SQL I C-22


Formato del Código SQL

Antes de la Operación
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

de Formateo

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
Después de la Operación a r d0 Stud
de Formateo
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Formato del a sSQL
icCódigo fe
R n
a formato al sangrado, espaciado, uso de mayúsculas y separación de líneas del
onque desee
Puede
c s n - trdar
i o SQL Developer dispone de una función para dar formato a código SQL.
Ed código nSQL.
Para dar formato al código SQL, haga clic con el botón derecho del mouse en el área de la sentencia
y seleccione Format SQL.
En el ejemplo de la diapositiva, antes de dar formato, las palabras clave del código SQL no están en
mayúscula y la sentencia no está sangrada correctamente. Después de dar formato, el código SQL
mejora el aspecto con las palabras clave en mayúscula y la sentencia sangrada correctamente.

Oracle Database: Conceptos Fundamentales de SQL I C-23


Uso de Fragmentos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Los fragmentos son fragmentos de código que puede ser


simplemente sintaxis o ejemplos.
Al colocar el cursor aquí, se
muestra la ventana Snippets. En
la lista desplegable, puede
seleccionar la categoría de
funciones que desee.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nsfe
Uso de Fragmentos
R
Es
s n ra utilizar determinados fragmentos de código al utilizar la hoja de trabajo de SQL
n que-tdesee
oposible
c
i al crearnoo editar un procedimiento o una función de PL/SQL. SQL Developer dispone de la función
Ed odenominada Snippets. Los fragmentos son fragmentos de código, como funciones SQL, indicaciones
del optimizador y otras técnicas de programación de PL/SQL. Puede arrastrar fragmentos a la
ventana Editor.
Para visualizar los fragmentos, seleccione View > Snippets.
Aparece la ventana Snippets a la derecha. Puede utilizar la lista desplegable para seleccionar un
grupo. En el margen de la ventana derecha se encuentra un botón Snippets, para poder acceder a la
ventana Snippets si se oculta.

Oracle Database: Conceptos Fundamentales de SQL I C-24


Uso de Fragmentos: Ejemplo
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Inserción de un
fragmento

s a
) ha
Edición del l ฺ c om
fragmento
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nsEjemplo
Uso de Fragmentos:
R fe
Paraoinsertar a
n un-trfragmento en el código en la hoja de trabajo de SQL o en otro procedimiento o
i c s o n
Ed función nPL/SQL, arrastre el fragmento desde la ventana Snippets hasta el lugar deseado del código.
A continuación, puede editar la sintaxis para que la función SQL sea válida en el contexto actual.
Para ver una descripción breve de una función SQL en una ayuda de burbuja, coloque el cursor sobre
el nombre de la función.
En el ejemplo de la diapositiva se muestra que CONCAT(char1, char2) se arrastra desde el
grupo Character Functions a la ventana Snippets. A continuación, se edita la sintaxis de la función
CONCAT y el resto de la sentencia se agrega como se describe a continuación:
SELECT CONCAT(first_name, last_name)
FROM employees;

Oracle Database: Conceptos Fundamentales de SQL I C-25


Depuración de Procedimientos y Funciones
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Utilizar SQL Developer para depurar funciones y


procedimientos PL/SQL.
• Utilizar la opción Compile for Debug para realizar una
compilación PL/SQL para que se pueda depurar el
procedimiento.
• Utilizar las opciones del menú a
Debug para definir puntos de
) has
división y realizar tareas o m
a i l ฺc
Step Into y Step Over. m ฺ
h ot uide
8 4 4@ ent G
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Depuraciónicde a Procedimientos
s fe y Funciones
n R r a n
i
En
c s o n -t puede depurar procedimiento y funciones PL/SQL. Con las opciones del menú
oSQL Developer,
Ed Debug, npuede realizar la siguientes tareas de depuración:
• Find Execution Point va al siguiente punto de ejecución.
• Resume continúa con la ejecución.
• Step Over omite el siguiente método y va a la siguiente sentencia después del método.
• Step Into va a la primera sentencia del siguiente método.
• Step Out deja el método actual y va a la siguiente sentencia.
• Step to End of Method va a la última sentencia del método actual.
• Pause para la ejecución pero no sale, lo que permite reanudar la ejecución.
• Terminate para y sale de la ejecución. No puede reanudar la ejecución desde este punto; en su
lugar, para iniciar la ejecución o depuración desde comienzo de la función o del procedimiento,
haga clic en el icono Run o Debug de la barra de herramientas del separador Source.
• Garbage Collection elimina los objetos no válidos de la caché en favor de objetos a los que se
accede con mayor frecuencia y más válidos.
Estas opciones también están disponibles como iconos en la barra de herramientas de depuración.

Oracle Database: Conceptos Fundamentales de SQL I C-26


Informes de Bases de Datos

SQL Developer proporciona un número predefinido de informes


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

sobre la base de datos y sus objetos.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Informes de a de
icBases s feDatos
R a n
SQL
c s onDeveloper
n - trproporciona diferentes informes sobre la base de datos y sus objetos. Estos informes
i o
Ed • Informes
se n
pueden agrupar en las siguientes
About Your Database
categorías:

• Informes Database Administration


• Informes Table
• Informes PL/SQL
• Informes Security
• Informes XML
• Informes Jobs
• Informes Streams
• Informes All Objects
• Informes Data Dictionary
• Informes User Defined
Para visualizar los informes, haga clic en el separador Reports situado a la izquierda de la ventana.
Los informes individuales se muestran en los paneles con separadores situados a la derecha de la
ventana y para cada informe puede seleccionar (en una lista desplegable) la conexión a la base de
datos para la que desea mostrar el informe. Para los informes sobre objetos, sólo se muestran aquellos
objetos que sean visibles para el usuario de la base de datos asociado a la conexión a la base de datos
seleccionada y las filas ordenadas por propietario. También puede crear sus propios informes
definidos por el usuario.
Oracle Database: Conceptos Fundamentales de SQL I C-27
Creación de un Informe Definido por el Usuario

Crear y guardar informes definidos por el usuario para un uso


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

repetido.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r i ch this
i r ez informes
Organizar
u se en carpetas.
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Creación de a Informe
icun s fe Definido por el Usuario
R n
Los
s n
oinformes
n - tra por el usuario son informes creados por los usuarios de SQL Developer. Para
definidos
i c o definido por el usuario, realice los siguientes pasos:
Ed crear unninforme
1. Haga clic con el botón derecho del mouse en el nodo User Defined Reports en Reports y
seleccione Add Report.
2. En el cuadro Create Report Dialog, especifique el nombre del informe y la consulta SQL para
recuperar del informe. A continuación, haga clic en Apply.
En el ejemplo de la diapositiva, se especifica el nombre del informe como emp_sal. Se proporciona
una descripción opcional que indica que el informe contiene los detalles de los empleados con un
salario salary >= 10000. La sentencia SQL completa para la recuperación de la información
que se mostrará en el informe definido por el usuario se especifica en el cuadro SQL. También puede
incluir una ayuda de burbuja opcional que se muestre al colocar el cursor brevemente sobre el
nombre del informe en la pantalla del navegador Reports.
Puede organizar los informes definidos por el usuario en carpetas y puede crear una jerarquía de
carpetas y subcarpetas. Para crear una carpeta para los informes definidos por el usuario, haga clic
con el botón derecho del mouse en el nodo User Defined Reports o en cualquier nombre de carpeta
de dicho nodo y seleccione Add Folder. La información sobre los informes definidos por el usuario,
incluidas las carpetas de dichos informes, se almacena en un archivo denominado
UserReports.xml en el directorio de información específica del usuario.

Oracle Database: Conceptos Fundamentales de SQL I C-28


Motores de Búsqueda y Herramientas Externas
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Accesos directos a herramientas


utilizadas con mayor frecuencia
1

2 s a
) ha
l ฺ c om
t m ai eฺ
Enlaces a motores de @ ho Guid
búsqueda y foros de 8 4 4 ent
discusión conocidos
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Motores deic a sfey Herramientas Externas
Búsqueda
n R r an
Para
s omejorar
n -
latproductividad de los desarrolladores de SQL, SQL Developer ha agregado enlaces
i c o
Ed rápidosna motores de búsqueda y foros de discusión conocidos, como AskTom, Google, etc. Además,
dispone de iconos de acceso directo a algunas de las herramientas más utilizadas, como el Bloc de
notas, Microsoft Word y Dreamweaver.
Puede agregar herramientas externas a la lista de herramientas existentes o incluso suprimir accesos
directos a las herramientas que no utilice habitualmente. Para ello, realice los siguientes pasos:
1. En el menú Tools, seleccione External Tools.
2. En el cuadro de diálogo External Tools, seleccione New para agregar nuevas herramientas.
Seleccione Delete para eliminar cualquier herramienta de la lista.

Oracle Database: Conceptos Fundamentales de SQL I C-29


Definición de Preferencias
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Personalizar la interfaz y el entorno de SQL Developer.


• En el menú Tools, seleccione Preferences.

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
icaPreferencias
Definición de
R n s fe
Puede
s n tra diferentes aspectos de la interfaz y el entorno de SQL Developer mediante la
onpersonalizar
-
i c no de las preferencias de SQL Developer según sus preferencias y necesidades. Para
Ed modificación modificar las preferencias de SQL Developer, seleccione Tools y, a continuación, Preferences.
Las preferencias se agrupan en las siguientes categorías:
• Environment
• Accelerators (accesos directos del teclado)
• Code Editors
• Database
• Debugger
• Documentation
• Extensions
• File Types
• Migration
• PL/SQL Compilers
• PL/SQL Debugger

Oracle Database: Conceptos Fundamentales de SQL I C-30


Restablecimiento del Diseño de SQL Developer
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica ndelsfDiseño
Restablecimiento
R
e de SQL Developer
Al n r a
-tSQL Developer, si desaparece el navegador de conexiones o no puede encajar la
otrabajar con
i c s o n
Ed ventana nLog en su lugar original, realice los siguientes pasos para solucionar el problema:
1. Salga de SQL Developer.
2. Abra una ventana de terminal y utilice el comando de búsqueda para buscar la ubicación de
windowinglayout.xml.
3. Vaya al directorio que contenga el archivo windowinglayout.xml y suprímalo.
4. Reinicie SQL Developer.

Oracle Database: Conceptos Fundamentales de SQL I C-31


Resumen
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

En este apéndice, debe haber aprendido cómo utilizar SQL


Developer para realizar las siguientes acciones:
• Examinar, crear y editar objetos de bases de datos
• Ejecutar sentencias SQL y scripts en la hoja de trabajo de
SQL
• Crear y guardar informes personalizados s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Resumen ica s fe
R n
SQL
s onDeveloper
n - tresauna herramienta gráfica gratuita para simplificar las tareas de desarrollo de la base
i c o
Ed de datos.nCon SQL Developer, puede examinar, crear y editar objetos de bases de datos. Puede
utilizar SQL Worksheet para ejecutar archivos de comandos y sentencias SQL. SQL Developer
permite crear y guardar su propio juego especial de informes para un uso repetido.

Oracle Database: Conceptos Fundamentales de SQL I C-32


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Uso de SQL*Plus

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Objetivos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Al finalizar este apéndice, debería estar capacitado para lo


siguiente:
• Conectarse a SQL*Plus
• Editar comandos SQL
• Formatear la salida con comandos SQL*Plus
• Interactuar con scripts s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Objetivos ica s fe
R n
a sentencias SELECT que se puedan utilizar repetidamente. En este apéndice
onque desee
Puede
c s n - trcrear
i o
Ed tambiénnse aborda el uso de comandos SQL*Plus para ejecutar sentencias SQL. Aprenderá cómo
formatear la salida mediante comandos SQL*Plus, editar comandos SQL y guardar scripts en
SQL*Plus.

Oracle Database: Conceptos Fundamentales de SQL I D-2


Interacción de SQL y SQL*Plus
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Sentencias SQL
Servidor
SQL*Plus

Resultados de consultas s a
) ha
l ฺ c om
Buffer
t m ai eฺ
@ ho Guid
8 4 4 ent
Scripts ha
rd0 Stud
SQL
z (ric e this
m ire to us
z Ra nse
o p e© 2010, lOracle
Copyright i c e y/o sus filiales. Todos los derechos reservados.
r d o L rable
SQL y SQL*Plus
R ica nsfe
SQL
s n tra de comandos que se utiliza para la comunicación con el servidor de Oracle desde
ones un lenguaje
-
i c noherramienta o aplicación. Oracle SQL contiene muchas extensiones. Al introducir una
Ed cualquier
sentencia SQL, ésta se almacena en una parte de la memoria denominada buffer SQL y permanece
allí hasta que introduzca una nueva sentencia SQL. SQL*Plus es una herramienta de Oracle que
reconoce y envía sentencias SQL en Oracle9i Server para su ejecución. Contiene su propio lenguaje
de comandos.
Funciones de SQL
• Las pueden utilizar una gran variedad de usuarios, incluidos aquéllos con poca o ninguna
experiencia
• .Es un lenguaje que no es de procedimientos.
• Reduce la cantidad de tiempo necesario para crear y mantener sistemas.
• Es un lenguaje como el inglés.
Funciones de SQL*Plus
• Acepta la entrada ad hoc de sentencias.
• Acepta la entrada de SQL de los archivos.
• Proporciona un editor de líneas para modificar sentencias SQL.
• Controla los valores de entorno.
• Formatea resultados de consulta en informes básicos.
• Accede a bases de datos locales y remotas.
Oracle Database: Conceptos Fundamentales de SQL I D-3
Sentencias SQL frente a 
Comandos SQL*Plus

SQL SQL*Plus
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Un lenguaje • Un entorno
• Estándar de ANSI • Propiedad de Oracle
• Las palabras clave no • Las palabras clave se
se pueden abreviar. pueden abreviar.
• Las sentencias manipulan • Los comandos no
definiciones de tablas permiten la manipulación as
a
y datos en la base de datos. de valores en la base de
m )h
datos. i l ฺ co
tam ideฺ
o
h Gu
4 4 @ n t
8
d0 Stud Buffer e
Sentencias Buffer r
Comandos
a
SQL SQL
( r ichSQL*Plusthis SQL*Plus
z
ire to us e
m
z Ra nse
o p e© 2010, lOracle
Copyright i c e y/o sus filiales. Todos los derechos reservados.
r d o L rable
SQL y SQL*Plus
R ica (continuación)
n s fe
Ens olansiguiente
n - ra compara SQL y SQL*Plus:
ttabla
i c o
Ed SQLn SQL*Plus
Lenguaje para la comunicación con el Reconoce las sentencias SQL y las envía al
servidor de Oracle para acceder a los datos. servidor.
Se basa en SQL del estándar ANSI Interfaz propiedad de Oracle para ejecutar
(American National Standards Institute). sentencias SQL.
Manipula la definiciones de tablas y datos en No permite la manipulación de valores en la
la base de datos. base de datos.
Se introduce en el buffer SQL en una o más Se introduce en una línea al mismo tiempo y
líneas. no se almacena en el buffer SQL.
No tiene ningún carácter de continuación. Utiliza un guión (–) como carácter de
continuación si el comando es más largo que
una línea.
No se puede abreviar. Se puede abreviar.
Utiliza un carácter de terminación para No necesita caracteres de terminación;
ejecutar comandos inmediatamente. ejecuta los comandos inmediatamente.
Utiliza funciones para realizar algunas tareas Utiliza comandos para formatear datos.
de formato.
Oracle Database: Conceptos Fundamentales de SQL I D-4
Visión General de SQL*Plus
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Conectarse a SQL*Plus.
• Describir la estructura de la tabla.
• Editar la sentencia SQL.
• Ejecutar SQL desde SQL*Plus.
• Guardar sentencias SQL en archivos y agregar sentencias
SQL a los archivos. a
• Ejecutar archivos guardados. ) has
c o m
• ailฺ ฺ
Cargar comandos del archivo en el buffer para la edición.
h otm uide
8 4 4@ ent G
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
SQL*Plus ica s fe
R n
a en el que puede:
on esnun
SQL*Plus
c s - trentorno
i no sentencias SQL para recuperar, modificar, agregar y eliminar datos de la base de datos.
Ed • Ejecutar • Formatear, realizar cálculos, almacenar e imprimir resultados de consulta en forma de informes.
• Crear scripts para almacenar sentencias SQL para un uso repetido en el futuro.
Los comandos SQL*Plus se pueden dividir en las siguientes categorías:

Categoría Objetivo
Entorno Afectar al comportamiento general de sentencias SQL para la sesión.
Formato Formatear resultados de consulta.
Manipulación de Guardar, cargar y ejecutar archivos de comandos.
archivos
Ejecución Enviar sentencias SQL del buffer SQL al servidor de Oracle.
Edición Modificar sentencias SQL en el buffer.
Interacción Crear y transferir variables a la sentencia SQL, imprimir valores de
variables y mensajes en la pantalla.
Otros Conectarse a la base de datos, manipular el entorno SQL*Plus y
mostrar definiciones de columnas.

Oracle Database: Conceptos Fundamentales de SQL I D-5


Conexión a SQL*Plus
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
sqlplus [username[/password[@database]]] ) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud 2
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Conexión aic a sfe
SQL*Plus
R
n de llamarr ana SQL*Plus dependerá del tipo de sistema operativo en que esté ejecutando
La
s o
forma - t
d n on
icOracle Database.
E Para conectarse desde un entorno Linux, realice los siguientes pasos:
1. Haga clic con el botón derecho del mouse en el escritorio de Linux y seleccione un terminal.
2. Introduzca el comando sqlplus que se muestra en la diapositiva.
3. Introduzca el nombre de usuario, la contraseña y el nombre de la base de datos.
En la sintaxis:
username Nombre de usuario de la base de datos.
password Contraseña de la base de datos (la contraseña será visible si la introduce aquí).
@database Cadena de conexión de la base de datos.
Nota: para asegurarse de la integridad de la contraseña, no la introduzca en la petición de datos del
sistema operativo. En su lugar, introduzca sólo el nombre de usuario. Introduzca la contraseña en la
petición de datos de la contraseña.

Oracle Database: Conceptos Fundamentales de SQL I D-6


Visualización de la Estructura de la Tabla

Utilizar el comando SQL*Plus DESCRIBE para mostrar la


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

estructura de una tabla:

DESC[RIBE] tablename

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Visualización
R icade lanEstructura
s fe de la Tabla
En o n r a
SQL*Plus,-tpuede mostrar la estructura de una tabla mediante el comando DESCRIBE. El
i c s odelncomando es una visualización de los nombres de columna y tipos de dato, así como una
d n
resultado
E indicación de si una columna debe contener datos.
En la sintaxis:
tablename Nombre de cualquier tabla existente, vista o sinónimo al que puede acceder
el usuario.
Para describir la tabla DEPARTMENTS, utilice este comando:
SQL> DESCRIBE DEPARTMENTS
Name Null? Type
----------------------- -------- ---------------

DEPARTMENT_ID NOT NULL NUMBER(4)


DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)

Oracle Database: Conceptos Fundamentales de SQL I D-7


Visualización de la Estructura de la Tabla
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

DESCRIBE departments

Name Null? Type


s a
----------------------- -------- ------------
) ha
DEPARTMENT_ID NOT NULL NUMBER(4)
l ฺ c om
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
t m ai eฺ
MANAGER_ID
LOCATION_ID
NUMBER(6)
NUMBER(4) @ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Visualización
R icade lanEstructura
s fe de Tabla (continuación)
n r a
-det la diapositiva se muestra la información sobre la estructura de la tabla
i
En
c soel ejemplo
o n
Ed Null?: n
DEPARTMENTS. En el resultado:
especifica si una columna debe contener datos (NOT NULL indica que una columna debe
contener datos).
Type: muestra el tipo de dato de una columna.

Oracle Database: Conceptos Fundamentales de SQL I D-8


Comandos de Edición SQL*Plus


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

A[PPEND] text
• C[HANGE] / old / new
• C[HANGE] / text /
• CL[EAR] BUFF[ER]
• DEL
• DEL n s a
• ) ha
DEL m n
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Comandoside
R caEdición n s feSQL*Plus
Los
s n
ocomandos
n - ra
tSQL*Plus se introducen en una línea al mismo tiempo y no se almacenan en el buffer
i c o
Ed SQL.Comando
n
Descripción
A[PPEND] text Agrega texto al final de la línea actual.
C[HANGE] / old / new Cambia el texto antiguo por el nuevo en la línea
actual.
C[HANGE] / text / Suprime el texto de la línea actual.
CL[EAR] BUFF[ER] Suprime todas las líneas del buffer SQL.
DEL Suprime la línea actual.
DEL n Suprime la línea n.
DEL m n Suprime de las líneas m hasta la n, inclusive.
Instrucciones
• Si pulsa Intro antes de que haya terminado la ejecución de un comando, SQL*Plus le solicitará
un número de línea.
• Termine el buffer SQL introduciendo uno de los caracteres de terminación (punto y coma o
barra) o pulsando [Intro] dos veces. Aparecerá la petición de datos SQL.

Oracle Database: Conceptos Fundamentales de SQL I D-9


Comandos de Edición SQL*Plus


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

I[NPUT]
• I[NPUT] text
• L[IST]
• L[IST] n
• L[IST] m n
• R[UN] s a
• ) ha
n
l ฺ c om
• n text
t m ai eฺ
• 0 text @ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Comandoside
R caEdiciónn s feSQL*Plus (continuación)
s n
oComando
n - tra
d c
i I[NPUT]
n o Descripción
E Inserta un número indefinido de líneas.
I[NPUT] text Inserta una línea que consta de texto.
L[IST] Muestra todas las líneas en el buffer SQL.
L[IST] n Muestra una línea (especificada por n).
L[IST] m n Muestra un rango de líneas (m a n), inclusive.
R[UN] Muestra y ejecuta la sentencia SQL actual en el buffer.
n Especifica la línea para crear la línea actual.
n text Sustituye la línea n con texto.
0 text Inserta una línea delante de la línea 1.
Nota: puede introducir sólo un comando SQL*Plus para cada petición de datos SQL. Los comandos
SQL*Plus no se almacenan en el buffer. Para que un comando SQL*Plus continúe en la siguiente
línea, finalice la primera línea con un guión (-).

Oracle Database: Conceptos Fundamentales de SQL I D-10


Uso de LIST, n y APPEND
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

LIST
1 SELECT last_name
2* FROM employees

1
1* SELECT last_name a
s
) ha
l ฺ c om
A , job_id
t m ai eฺ
1* SELECT last_name, job_id
@ ho Guid
8 4 4 ent
LIST a r d0 Stud
1 SELECT last_name, job_id ( r ich this
2* FROM employees irez u se
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Uso de LIST,
R ican y APPEND
n s fe
• on
s ra L[IST] para mostrar el contenido del buffer SQL. El asterisco (*) situado
Utilice el-tcomando
n
i c noa la línea 2 en el buffer indica que la línea 2 es la línea actual. Cualquier edición que
Ed junto
realice se aplica a la línea actual.
• Introduzca el número (n) de la línea que desea editar para cambiar el número de la línea actual.
Se muestra la nueva línea actual.
• Utilice el comando A[PPEND] para agregar texto a la línea actual. Se muestra la línea recién
editada. Verifique el nuevo contenido del buffer mediante el comando LIST.
Nota: muchos de los comandos SQL*Plus, incluidos LIST y APPEND, se pueden abreviar sólo con
su primera letra. LIST se puede abreviar con L; APPEND se puede abreviar con A.

Oracle Database: Conceptos Fundamentales de SQL I D-11


Uso del Comando CHANGE
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

LIST
1* SELECT * from employees

c/employees/departments
s a
1* SELECT * from departments
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
LIST 8 4 4 ent
1* SELECT * from departments ard
0 tud
r i c h his S
z ( e t
r e s
a mi e to u
z R ns
o p e
Copyright
l i c e y/o sus filiales. Todos los derechos reservados.
© 2010, Oracle

r d o L rable
ica nCHANGE
Uso del Comando
R s fe
• on
s - tra para mostrar el contenido del buffer.
Utilice L[IST]
n
i c no el comando C[HANGE] para modificar el contenido de la línea actual del buffer SQL.
Ed • Utilice
En este caso, sustituya la tabla employees por la tabla departments. Se muestra la nueva
línea actual.
• Utilice el comando L[IST] para verificar el nuevo contenido del buffer.

Oracle Database: Conceptos Fundamentales de SQL I D-12


Comandos de Archivos SQL*Plus


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SAVE filename
• GET filename
• START filename
• @ filename
• EDIT filename
• SPOOL filename s a
• ) ha
EXIT
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Comandoside
R caArchivos
n s fe SQL*Plus
n
Lasosentencias
s n - ra se comunican con el servidor de Oracle. Los comandos SQL*Plus controlan el
tSQL
c
i entorno, formatean
o los resultados de la consulta y gestionan archivos. Puede utilizar los comandos
Ed descritosnen la siguiente tabla:
Comando Descripción
SAV[E] filename [.ext] Guarda el contenido actual del buffer SQL en un archivo.
[REP[LACE]APP[END]] Utilice APPEND para agregar a un archivo existente; utilice
REPLACE para sobrescribir un archivo existente. La extensión
por defecto es .sql.
GET filename [.ext] Escribe el contenido de un archivo guardado anteriormente en
el buffer SQL. La extensión por defecto del nombre de archivo
es .sql.
STA[RT] filename [.ext] Ejecuta el archivo de comandos guardado anteriormente.
@ filename Ejecuta un archivo de comandos guardado anteriormente (igual
que START).
ED[IT] Llama al editor y guarda el contenido del buffer en un archivo
denominado afiedt.buf.
ED[IT] [filename[.ext]] Llama al editor para editar el contenido de un archivo guardado.
SPO[OL] [filename[.ext]| Almacena los resultados de la consulta en un archivo. OFF
OFF|OUT] cierra el archivo de spool. OUT cierra el archivo de spool y
envía los resultados del archivo a la impresora.
EXIT Sale de SQL*Plus.

Oracle Database: Conceptos Fundamentales de SQL I D-13


Uso de los Comandos SAVE, START
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

LIST
1 SELECT last_name, manager_id, department_id
2* FROM employees

SAVE my_query
Created file my_query
s a
) ha
START my_query
l ฺ c om
LAST_NAME MANAGER_ID DEPARTMENT_ID t m ai eฺ
------------------------- ---------- ------------- @ ho Guid
King 8 4 4 ent 90
Kochhar
a r
100d0 Stud 90
...
( r ich this
107 rows selected.
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ca nsfeSAVE, START y EDIT
Uso de los iComandos
R
SAVE
c s on n-tra
i nel ocomando SAVE para almacenar el contenido actual del buffer en un archivo. De esta forma,
Ed Utilice
podrá almacenar los scripts utilizados con frecuencia para utilizarlos en el futuro.
START
Utilice el comando START para ejecutar un script en SQL*Plus. Además, también puede utilizar el
símbolo @ para ejecutar un script.
@my_query

Oracle Database: Conceptos Fundamentales de SQL I D-14


Comando SERVEROUTPUT

• Utilizar el comando SET SERVEROUT[PUT] para controlar


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

si se debe mostrar la salida de los procedimientos


almacenados o bloques PL/SQL en SQL*Plus.
• El límite de longitud de la línea DBMS_OUTPUT ha
aumentado de 255 a 32767 bytes.
• El tamaño por defecto es ahora ilimitado. a
• Los recursos no se asignan previamente si se define ) has
SERVEROUTPUT. o m
a ilฺc ฺ
• otm uaide
Ya que no afecta al rendimiento, utilice UNLIMITED
h
@ tG
menos que desee conservar la memoria4física.
4 den
0 8
SET SERVEROUT[PUT] {ON | OFF} [SIZEh{n a rd| UNL[IMITED]}]
S tu
[FOR[MAT] {WRA[PPED] | WOR[D_WRAPPED]
z (ric e thi|s TRU[NCATED]}]
m ire to us
z Ra nse
o p e© 2010, lOracle
Copyright i c e y/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nsfe
Comando SERVEROUTPUT
R
La
s n de-tlosraprogramas PL/SQL realizan entradas y salidas mediante sentencias SQL para
omayoría
d c
i almacenar
n n en las tablas de las bases de datos o consultar dichas tablas. Las demás
odatos
E entradas/salidas PL/SQL se realizan a través de API, que interactúan con otros programas. Por
ejemplo, el paquete DBMS_OUTPUT tiene procedimientos, como PUT_LINE. Para ver el resultado
fuera de PL/SQL, se necesita otro programa como SQL*Plus, para leer y visualizar los datos
transferidos a DBMS_OUTPUT.
SQL*Plus no muestra los datos de DBMS_OUTPUT a menos que antes emita el comando SQL*Plus
SET SERVEROUTPUT ON siguiente:
SET SERVEROUTPUT ON
Nota
• SIZE define el número de bytes de la salida que se pueden almacenar en buffer en el servidor
de Oracle Database. El valor por defecto es UNLIMITED. n no puede ser menor que 2.000 o
mayor que 1.000.000.
• Para obtener más información sobre SERVEROUTPUT, consulte Oracle Database PL/SQL
User's Guide and Reference 11g (Guía del Usuario y Referencia de PL/SQL de Oracle
Database 11g).

Oracle Database: Conceptos Fundamentales de SQL I D-15


Uso del Comando SQL*Plus SPOOL
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SPO[OL] [file_name[.ext] [CRE[ATE] | REP[LACE] |


APP[END]] | OFF | OUT]

Opción Descripción

file_name[.ext] Envía la salida al nombre de archivo especificado.

CRE[ATE] Crea un nuevo archivo con el nombre especificado.


s a
REP[LACE] Sustituye el contenido de un archivo existente. Si el ) ha
c om
archivo no existe, REPLACE crea el archivo.
l ฺ
a i ฺ
APP[END] Agrega el contenido del buffer al finalodel archivo t m ide
h u
especificado.
8 4 4@ ent G
OFF Para el envío de resultados.
a r d0 Stud
OUT Para el envío ( r icdeh datosthyisenvía el archivo a la
r ez estándar
impresora
i u se (por defecto) de la computadora.
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nSQL*Plus
Uso del Comando
R s fe SPOOL
on nSPOOL
El comando
s - tra almacena los resultados de la consulta en un archivo o envía el archivo a una
i c noSe ha mejorado el comando SPOOL. Ahora puede adjuntar a (o sustituir) un archivo
Ed impresora.
existente, cuando antes sólo podía utilizar SPOOL para crear (y sustituir) un archivo. REPLACE es el
valor por defecto.
Para enviar la salida generada por los comandos en un script sin mostrar la salida en la pantalla,
utilice SET TERMOUT OFF. SET TERMOUT OFF no afecta a la salida de los comandos que se
ejecutan interactivamente.
Debe utilizar comillas con los nombres de archivo que contengan espacios en blanco. Para crear un
archivo HTML válido mediante los comandos SPOOL APPEND, debe utilizar PROMPT o un
comando para crear la cabecera y el pie de página de la página HTML. El comando SPOOL
APPEND no analiza las etiquetas HTML. SET SQLPLUSCOMPAT[IBILITY] en 9.2 o anterior
para desactivar los parámetros CREATE, APPEND y SAVE.

Oracle Database: Conceptos Fundamentales de SQL I D-16


Uso del Comando AUTOTRACE
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Muestra un informe después de la ejecución correcta de


sentencias DML de SQL, como SELECT, INSERT, UPDATE
o DELETE.
• El informe puede incluir ahora estadísticas de ejecución y
la ruta de acceso de ejecución de la consulta.

s a
SET AUTOT[RACE] {ON | OFF | TRACE[ONLY]} [EXP[LAIN]] ) ha
[STAT[ISTICS]]
l ฺ c om
t m ai eฺ
SET AUTOTRACE ON @ ho Guid
-- The AUTOTRACE report includes both 8 4
the
4 optimizer
e n t
-- execution path and the SQL statement a r d0 Sexecutiont ud
-- statistics ( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nAUTOTRACE
Uso del Comando
R s fe
on muestra
EXPLAIN
s n - tra la ruta de acceso de ejecución de consulta mediante la ejecución de EXPLAIN
c
i PLAN. STATISTICS
no
Ed puede muestra estadísticas de sentencias SQL. El formato del informe AUTOTRACE
variar en función de la versión del servidor al que está conectado y la configuración del
servidor. El paquete DBMS_XPLAN proporciona una forma fácil de mostrar la salida del comando
EXPLAIN PLAN en varios formatos predefinidos.
Nota
• Para obtener más información sobre el paquete y los subprogramas, consulte Oracle Database
PL/SQL Packages and Types Reference 11g (Referencia sobre Paquetes y Tipos PL/SQL de
Oracle Database 11g).
• Para obtener más información sobre EXPLAIN PLAN, consulte Oracle Database SQL
Reference 11g (Referencia sobre SQL de Oracle Database 11g).
• Para obtener más información sobre las estadísticas de planes de ejecución, consulte
Oracle Database Performance Tuning Guide 11g (Guía de Ajuste del Rendimiento de
Oracle Database 11g).

Oracle Database: Conceptos Fundamentales de SQL I D-17


Resumen
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

En este apéndice, debe haber aprendido cómo utilizar


SQL*Plus como un entorno para realizar las siguientes
acciones:
• Ejecutar sentencias SQL
• Editar sentencias SQL
• Formatear la salida s a
• Interactuar con scripts ) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Resumen ica s fe
R n
a de ejecución que puede utilizar para enviar comandos SQL al servidor de la
on esnun
SQL*Plus
c s - trentorno
i nopara editar y guardar los comandos SQL. Puede ejecutar los comandos desde la petición
Ed base datos de datos SQL o desde un archivo de script.

Oracle Database: Conceptos Fundamentales de SQL I D-18


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Uso de JDeveloper

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Objetivos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Al finalizar este apéndice, debería estar capacitado para lo


siguiente:
• Mostrar las funciones clave de Oracle JDeveloper
• Crear una conexión a base de datos en JDeveloper
• Gestionar objetos de base de datos en JDeveloper
• Utilizar JDeveloper para ejecutar comandos SQL s a
• Crear y ejecutar unidades de programa PL/SQL ) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Objetivos ica s fe
R n
En s onapéndice,
este n - trseapresentará JDeveloper. Aprenderá cómo utilizar JDeveloper para las tareas de
i c o
Eddesarrollonde la base de datos.

Oracle Database: Conceptos Fundamentales de SQL I E-2


Oracle JDeveloper
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nsfe
Oracle JDeveloper
R
Oracle
s n traes un entorno de desarrollo de integración (IDE) para desarrollar y desplegar
onJDeveloper
-
i c no Java y servicios web. Soporta cada etapa del ciclo de vida de desarrollo de software
Ed aplicaciones
(SDLC), del modelado al despliegue. Tiene funciones que permiten utilizar los últimos estándares de
la industria para Java, XML y SQL y desarrollar una aplicación.
Oracle JDeveloper 11g inicia un nuevo enfoque al desarrollo J2EE con funciones que permiten un
desarrollo visual y declarativo. Este enfoque innovador hace que el desarrollo J2EE sea sencillo y
eficaz.

Oracle Database: Conceptos Fundamentales de SQL I E-3


Database Navigator
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nsfe
Database Navigator
R
Con
s n - tra puede almacenar la información necesaria para conectarse a la base de datos
n JDeveloper,
oOracle
c
i un objeto
no denominado “conexión”. Una conexión se almacena como parte de los valores de IDE y
Ed en
se puede exportar e importar para compartirla fácilmente entre grupos de usuarios. Una conexión
tiene diferentes fines, desde el examen de la base de datos y la creación de aplicaciones hasta el
despliegue.

Oracle Database: Conceptos Fundamentales de SQL I E-4


Creación de Conexión
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Haga clic en el icono


1 New Connection en
Database Navigator.

2 En la ventana Create Database s a


Connection, introduzca el
) ha
usuario, la contraseña y el SID.
l ฺ c om
t m ai eฺ
3 Haga clic en Test Connection. @ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez4 usHaga e clic en OK.
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Creación de a sfe
icConexión
n R r aunnobjeto que especifica la información necesaria para conectarse a una base de
Una
s oconexión - t
es
d n on como usuario específico de dicha base de datos. Puede crear y probar conexiones para
icdatos concreta
E varias bases de datos y esquemas.
Para crear una conexión a la base de datos, realice los siguientes pasos:
1. Haga clic en el icono New Connection en Database Navigator.
2. En la ventana Create Database Connection, introduzca el nombre de la conexión. Introduzca el
nombre de usuario y la contraseña del esquema al que desea conectarse. Introduzca el SID de la
base de datos a la que desea conectarse.
3. Haga clic en Test para asegurarse de que la conexión se ha definido correctamente.
4. Haga clic en OK.

Oracle Database: Conceptos Fundamentales de SQL I E-5


Examen de Objetos de Bases de Datos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Utilizar el navegador de la base de datos para:


• Examinar los objetos de un esquema de base de datos
• Revisar las definiciones de objetos de forma rápida

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Examen deic a sdefeBases de Datos
Objetos
R n
n creada-trlaaconexión
Una
c s ovez
n a la base de datos, puede utilizar el navegador de la base de datos para
i o
Ed examinarn los objetos de un esquema de base de datos entre los que se incluyen tablas, vistas, índices,
paquetes, procedimientos, disparadores y tipos.
Puede ver la definición de los objetos desglosados en separadores de información que se transfieren
al diccionario de datos. Por ejemplo, si selecciona una tabla en el navegador, se muestran los detalles
sobre las columnas, restricciones, permisos, estadísticas, disparadores, etc., en un navegador de la
base de datos fácil de leer.

Oracle Database: Conceptos Fundamentales de SQL I E-6


Ejecución de Sentencias SQL
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

2
s a
) ha
l ฺ c om
t m ai eฺ
3 @ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Ejecuciónicde a Sentencias
s fe SQL
R n
Para
s n
oejecutar
n - trasentencia SQL, realice los siguientes pasos:
una
i c noclic en el icono Open SQL Worksheet.
Ed 1. Haga
2. Seleccione la conexión.
3. Ejecute el comando SQL haciendo clic en:
1. El botón Execute statement o pulsando F9. La salida es la siguiente:

2. El botón Run Script o pulsando F5. La salida es la siguiente:

Oracle Database: Conceptos Fundamentales de SQL I E-7


Creación de Unidades de Programa
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

2
s a
) ha
l ฺ c om
1 t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this 3
z e
ire to us Esqueleto de la Función
m
z Ra nse
o p e© 2010, lOracle
Copyright i c e y/o sus filiales. Todos los derechos reservados.
r d o L rable
Creación de a sfede Programa
icUnidades
R an de programa PL/SQL, realice los siguientes pasos:
n una-tunidad
r
s o
Para crear
d n on View > Database Navigator. Seleccione y amplíe una conexión de base de datos.
ic 1. Seleccione
E Haga clic con el botón derecho del mouse en una carpeta que corresponda al tipo de objeto
(Procedures, Packages, Functions). Seleccione “New [Procedures|Packages|Functions]”.
2. Introduzca un nombre válido para la función, el paquete o el procedimiento y haga clic en OK.
3. Se crea una estructura básica que se abre en la ventana Code Editor. A continuación, puede
editar el subprograma para que se ajuste a sus necesidades.

Oracle Database: Conceptos Fundamentales de SQL I E-8


Compilación
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Compilación con Errores


s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
Compilacióni r ez sinuErroresse
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Compilación
R ica nsfe
Después
s - trala definición de esqueleto, debe compilar la unidad de programa. Haga clic con el
on de neditar
i c no del mouse en el objeto PL/SQL que necesita compilar en Connection Navigator y, a
Ed botón derecho
continuación, seleccione Compile. También puede pulsar [Ctrl] + [Shift] + [F9] para compilar.

Oracle Database: Conceptos Fundamentales de SQL I E-9


Ejecución de una Unidad de Programa
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Ejecución de
R icauna nUnidad
s fe de Programa
Para n
oejecutar -
la a de programa, haga clic con el botón derecho del mouse en el objeto y haga
trunidad
i c s n
no Aparece el cuadro de diálogo Run PL/SQL. Puede que tenga que cambiar los valores
Ed clic en Run. NULL por valores razonables que se transfieren a la unidad de programa. Después de cambiar los
valores, haga clic en OK. La salida se mostrará en la ventana Message-Log.

Oracle Database: Conceptos Fundamentales de SQL I E-10


Borrado de una Unidad de Programa
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
1
@ ho Guid
8 4 4 ent
a r d0 Stud 2
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Borrado deic a Unidad
una s fede Programa
R n
a de programa, haga clic con el botón derecho del mouse en el objeto y
n una-trunidad
Para
c s oborrar n
i noDrop. Aparece el cuadro de diálogo Drop Confirmation; haga clic en Apply. El objeto se
Ed seleccione
borra de la base de datos.

Oracle Database: Conceptos Fundamentales de SQL I E-11


Ventana Structure
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nsfe
Ventana Structure
R
Las n - tra ofrece una vista estructural de los datos del documento seleccionados
n Structure
oventana
i c no en la ventana activa de las ventanas que proporcionan estructura: navegadores, editores,
Ed actualmente
visores y el inspector de propiedades.
Haga clic en la ventana View > Structure para ver la ventana Structure.
En la ventana Structure, puede ver los datos del documento de distintas formas. Las estructuras
disponibles están basadas en el tipo de documento. Para un archivo Java, puede ver la estructura del
código, la estructura de la interfaz de usuario o los datos de modelo de interfaz de usuario. Para un
archivo XML, puede ver la estructura XML, la estructura del diseño o los datos de modelo de
interfaz de usuario.
La ventana Structure es dinámica y realiza siempre un seguimiento de la selección actual de la
ventana activa (a menos que congele el contenido de la ventana en una vista concreta), ya que está
relacionada con el editor que está actualmente activo. Cuando la selección actual es un nodo del
navegador, se asume el editor por defecto. Para cambiar la vista en la estructura de la selección
actual, haga clic en un separador de estructura distinto.

Oracle Database: Conceptos Fundamentales de SQL I E-12


Ventana del Editor
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
a sfe
Ventana delicEditor
R
n doble-tclic
r anen el nombre de una unidad de programa, se abre en la ventana del editor. Puede
Al
s o
hacer
d icver todosnolosnarchivos de proyectos en una única ventana del editor, abrir varias vistas del mismo
E archivo o abrir varias vistas de diferentes archivos.
Los separadores situados en la parte superior de la ventana del editor son los separadores del
documento. Al hacer clic en un separador del documento, dicho documento se enfoca y se coloca en
primer plano en la ventana del editor actual.
Los separadores situados en la parte inferior de la ventana del editor para un archivo concreto son los
separadores del editor. Al seleccionar un separador del editor, el archivo se abre en ese editor.

Oracle Database: Conceptos Fundamentales de SQL I E-13


Navegador de Aplicaciones
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Navegadoride
R caAplicaciones
n s fe
Elsnavegador a
on n-detraplicaciones proporciona una vista lógica de la aplicación y de los datos que
i c o
Ed contiene.
n Además proporciona una infraestructura a la que las distintas extensiones pueden
conectarse y utilizar para organizar los datos y menús de forma abstracta y consistente. Aunque el
navegador de aplicaciones puede contener archivos individuales (como archivos de origen Java), está
diseñado para consolidar datos complejos. Los tipos de dato complejos, como los objetos de
entidades, diagramas UML, EJB o servicios web aparecen en el navegador como nodos únicos. Los
archivos raw que componen estos nodos abstractos aparecen en la ventana Structure.

Oracle Database: Conceptos Fundamentales de SQL I E-14


Despliegue de Procedimientos Java Almacenados
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Antes de desplegar procedimientos Java almacenados, realice


los siguientes pasos:
1. Cree una conexión a la base de datos.
2. Cree un perfil de despliegue.
3. Despliegue los objetos.
s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
1 2rich this
( 3
z
ire to us e
m
z Ra nse
o p e© 2010, lOracle
Copyright i c e y/o sus filiales. Todos los derechos reservados.
r d o L rable
Despliegueic deaProcedimientos
s fe Java Almacenados
n R r a n
i
Cree
c s o un perfil
o n -det despliegue para los procedimientos Java almacenados y, a continuación, despliegue
Ed las n y, si lo desea, cualquier método estático público en JDeveloper con los valores del perfil.
clases
El despliegue en la base de datos utiliza la información proporcionada en Deployment Profile Wizard
y dos utilidades de Oracle Database:
• loadjava carga la clase Java que contiene los procedimientos almacenados en Oracle
Database.
• publish genera los envoltorios específicos de llamada PL/SQL para los métodos estáticos
públicos cargados. La publicación permite que se llame a los métodos Java como funciones o
procedimientos PL/SQL.

Oracle Database: Conceptos Fundamentales de SQL I E-15


Publicación de Java en PL/SQL
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 2Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Publicaciónicde a Javasen fePL/SQL
R n
Las n
odiapositiva
n - tra el código Java y cómo publicar el código Java en un procedimiento PL/SQL.
muestra
i c no
Ed

Oracle Database: Conceptos Fundamentales de SQL I E-16


¿Cómo Puedo Obtener más Información sobre
JDeveloper 11g?
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Tema Dirección web


Página del Producto
Oracle JDeveloper http://www.oracle.com/technology/products/jdev/index.html
Tutoriales de Oracle
JDeveloper 11g http://www.oracle.com/technology/obe/obe11jdev/11/index.html
Documentación de los s a
Productos Oracle
JDeveloper 11g
http://www.oracle.com/technology/documentation/jdev.html
) ha
Foro de Discusión de l ฺ c om
http://forums.oracle.com/forums/forum.jspa?forumID=83
Oracle JDeveloper 11g
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I E-17


Resumen
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

En este apéndice, debe haber aprendido a realizar lo siguiente:


• Mostrar las funciones clave de Oracle JDeveloper
• Crear una conexión a base de datos en JDeveloper
• Gestionar objetos de base de datos en JDeveloper
• Utilizar JDeveloper para ejecutar comandos SQL
• Crear y ejecutar unidades de programa PL/SQL s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I E-18


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Sintaxis de Unión en Oracle

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Objetivos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Al finalizar este apéndice, debería estar capacitado para lo


siguiente:
• Escribir sentencias SELECT para acceder a datos de más
de una tabla mediante uniones igualitarias y no igualitarias
• Unir una tabla consigo misma mediante autounión
• Ver datos que normalmente no cumplen una condición de a
unión mediante uniones externas ) has
o m
• Generar un producto cartesiano de todas las filas deiluna
a ฺc o
más tablas otm ideฺ
h Gu
4 4 @ n t
8
d0 Stud e
a r
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Objetivos ica s fe
R n
Esta
s n explica
olecciónn - tra cómo obtener datos de más de una tabla. Una unión se utiliza para ver
i c no de varias tablas. Por lo tanto, puede unir tablas para ver información de más de una
Ed información tabla.
Nota: para obtener más información sobre las uniones, consulte la sección sobre consultas y
subconsultas SQL: uniones en Oracle Database SQL Language Reference 11g, Release 1 (11.1)
(Referencia sobre Lenguaje SQL de Oracle Database 11g, Versión 1 (11.1)).

Oracle Database: Conceptos Fundamentales de SQL I F-2


Obtención de Datos de Varias Tablas
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

EMPLOYEES DEPARTMENTS

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
… ( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Obtención ide
R caDatos n s feVarias Tablas
de
on necesita
Asveces,
n - trautilizar datos de más de una tabla. En el ejemplo de la diapositiva, el informe
i c o
Ed muestrandatos de dos tablas independientes:
• La tabla EMPLOYEES contiene los ID de empleado.
• Las tablas EMPLOYEES y DEPARTMENTS contienen los ID de departamento.
• La tabla DEPARTMENTS contiene los nombres de departamento.
Para producir el informe, necesita enlazar las tablas EMPLOYEES y DEPARTMENTS y acceder a los
datos de ambas.

Oracle Database: Conceptos Fundamentales de SQL I F-3


Productos Cartesianos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Un producto cartesiano se forma cuando:


– Se omite una condición de unión
– Una condición de unión no es válida
– Todas las filas de la primera tabla se unen a todas las filas
de la segunda tabla
• Para evitar un producto cartesiano, incluya siempre una a
s
condición de unión válida en una cláusula WHERE.
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ca nsfe
Productos iCartesianos
R
Cuando
s - tra de unión no es válida o se omite completamente, el resultado es un producto
on unancondición
i c no en el que se muestran todas las combinaciones de filas. Es decir, todas las filas de la
Ed cartesiano,
primera tabla se unen a todas las filas de la segunda tabla.
Un producto cartesiano tiende a generar un gran número de filas y el resultado es poco útil. Por lo
tanto, debe incluir siempre una condición de unión válida a menos que tenga necesidades específicas
de combinar todas las filas de todas las tablas.
Sin embargo, los productos cartesianos son útiles para algunas pruebas para las que necesite generar
un gran número de filas para simular una cantidad razonable de datos.

Oracle Database: Conceptos Fundamentales de SQL I F-4


Generación de un Producto Cartesiano
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

EMPLOYEES (20 filas) DEPARTMENTS (8 filas)

s a
) ha
l ฺ c om
Producto cartesiano:
t m ai eฺ
20 x 8 = 160 filas
@ ho Guid

8 4 4 ent
a r d0 Stud
… ( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Generaciónicde a un Producto
s fe Cartesiano
R n
Se
s n - tra cartesiano si se omite una condición de unión. En el ejemplo de la diapositiva
n un producto
ogenera
c
i se muestra
noel apellido del empleado y el nombre del departamento de las tablas EMPLOYEES y
Ed DEPARTMENTS, respectivamente. Ya que no se ha especificado ninguna condición de unión, todas
las filas (20 filas) de la tabla EMPLOYEES se unen con todas las filas (8 filas) de la tabla
DEPARTMENTS, por lo que se generan 160 filas en la salida.
SELECT last_name, department_name dept_name
FROM employees, departments;

Oracle Database: Conceptos Fundamentales de SQL I F-5


Tipos de Uniones Propiedad de Oracle
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Unión igualitaria
• Unión no igualitaria
• Unión externa
• Autounión

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nsfe
Tipos de Uniones
R
Para n tablas,
ounir - a utilizar la sintaxis de unión de Oracle.
trpuede
i c s n
Ed Nota: no de la versión de Oracle9i , la sintaxis de unión era propietaria. La sintaxis de unión
antes
compatible con SQL:1999 no ofrece ninguna ventaja en el rendimiento respecto a la sintaxis de
unión propietaria de Oracle.
Oracle no tiene una sintaxis equivalente para soportar FULL OUTER JOIN de la sintaxis de unión
compatible con SQL:1999.

Oracle Database: Conceptos Fundamentales de SQL I F-6


Unión de Tablas mediante la Sintaxis de Oracle
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

Utilizar una unión para consultar datos de más de una tabla:

SELECT table1.column, table2.column


FROM table1, table2
WHERE table1.column1 = table2.column2;

• Escribir la condición de unión en la cláusula WHERE. s a


• Incluya el nombre de tabla como prefijo en el nombre deom ) ha
columna cuando aparezca el mismo nombre de columnaa ilฺc ฺ
m
en más de una tabla. hot uide
8 4 4@ ent G
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica mediante
Unión de Tablas
R n s fe la Sintaxis de Oracle
Cuando
s n tra datos de más de una tabla en la base de datos, se utiliza una condición de unión.
on se necesitan
-
c
i filasndeo una tabla se pueden unir a las de otra de acuerdo con los valores comunes que existen en
Ed Las
columnas correspondientes (es decir, éstas suelen ser columnas de clave primaria y de clave ajena).
Para visualizar datos de dos o más tablas relacionadas, escriba una condición de unión simple en la
cláusula WHERE.
En la sintaxis:
table1.column Indica la tabla y la columna desde las que se recuperan los datos
table1.column1 = Es la condición que une (o relaciona) las tablas
table2.column2
Instrucciones
• Cuando escriba una sentencia SELECT para unir tablas, anteponga el nombre de la tabla al de
columna para mejorar la claridad y el acceso a la base de datos.
• Si aparece el mismo nombre de columna en más de una tabla, el nombre de columna debe tener
como prefijo el nombre de tabla.
• Para unir n tablas, necesita un mínimo de n-1 condiciones de unión. Por ejemplo, para unir
cuatro tablas, es necesario un mínimo de tres uniones. Esta regla puede que no se aplique si la
tabla tiene una clave primaria concatenada, en cuyo caso es necesario más de una columna para
identificar de forma única cada fila.

Oracle Database: Conceptos Fundamentales de SQL I F-7


Cualificación de Nombres de Columna Ambiguos
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Utilizar prefijos de tabla para cualificar los nombres de


columna que están en varias tablas.
• Utilizar prefijos de tabla para mejorar el rendimiento.
• Utilizar alias de tabla, en lugar de prefijos de nombre de
tabla completos.
• Los alias de tabla proporcionan un nombre más corto de s a
una tabla.
m ) ha
– Mantiene el código SQL más pequeño, utiliza menos ilฺco
memoria tma eฺ ho id
• @
Utilizar alias de columna para distinguir columnas G u
que
8 4 t
4 denendiferentes
tienen nombres idénticos, pero que residen
0
tablas. h a rd Stu
(r e th ic is
z
ire to us
m
z Ra nse
o p e© 2010, lOracle
Copyright i c e y/o sus filiales. Todos los derechos reservados.
r d o L rable
Cualificación
R icade Nombres
n s fe de Columna Ambiguos
Al o
s unir
n tratablas, debe cualificar los nombres de las columnas con el nombre de la tabla para
n dos o -más
c
i evitar ambigüedad.
no de laSintablalos prefijos de tabla, la columna DEPARTMENT_ID de la lista SELECT
Ed puede provenir DEPARTMENTS o de la tabla EMPLOYEES. Por lo tanto, es necesario
agregar el prefijo de tabla para ejecutar la consulta. Si no existen nombres de columna comunes entre
las dos tablas, no es necesario cualificar las columnas. Sin embargo, el uso del prefijo de tabla mejora
el rendimiento, ya que indica al servidor de Oracle dónde encontrar exactamente las columnas.
La cualificación de nombres de columna con nombres de tabla puede llevar bastante tiempo,
especialmente si los nombres de tabla son largos. Puede utilizar los alias de tabla, en lugar de los
nombres de tabla. Igual que un alias de columna proporciona otro nombre a una columna, un alias de
tabla proporciona otro nombre a una tabla. Los alias de tabla ayudan a mantener el código SQL más
pequeño y, por lo tanto, hay menos uso de memoria.
El nombre de tabla se especifica por completo, seguido de un espacio y del alias de tabla. Por
ejemplo, a la tabla EMPLOYEES se le puede proporcionar el alias e y a la tabla DEPARTMENTS el
alias d.
Instrucciones
• Los alias de tabla pueden tener hasta 30 caracteres de longitud, pero los alias más cortos son
mejores que los largos.
• Si se utiliza un alias de tabla para un nombre de tabla determinado en la cláusula FROM, el alias
de tabla se deberá sustituir por el nombre de tabla mediante la sentencia SELECT.
• Los alias de tabla deben ser significativos.
• El alias de tabla es válido sólo para la sentencia actual SELECT.
Oracle Database: Conceptos Fundamentales de SQL I F-8
Uniones igualitarias

EMPLOYEES DEPARTMENTS
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
m ) ha
… l ฺ c o
t m ai eฺ
Clave primaria
@ ho Guid
Clave ajena 8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nsfe
Uniones igualitarias
R
Para
s n
odeterminar
n - trelanombre de departamento de un empleado, compare el valor de la columna
i c no
Ed DEPARTMENT_ID en la tabla EMPLOYEES con los valores de DEPARTMENT_ID de la tabla
DEPARTMENTS. La relación entre las tablas EMPLOYEES y DEPARTMENTS es una unión
igualitaria; es decir, los valores de la columna DEPARTMENT_ID de ambas tablas deben ser iguales.
A menudo, este tipo de unión implica complementos de clave primaria y ajena.
Nota: las uniones igualitarias también se denominan uniones simples o uniones internas.

Oracle Database: Conceptos Fundamentales de SQL I F-9


Recuperación de Registros con Uniones
Igualitarias
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT e.employee_id, e.last_name, e.department_id,


d.department_id, d.location_id
FROM employees e, departments d
WHERE e.department_id = d.department_id;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
… i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Recuperación
R icade Registros
n s fe con Uniones Igualitarias
Ens oelnejemplo
n - trala diapositiva:
de
i c o
Ed • Lan- cláusula SELECT especifica los nombres de columna que se van a recuperar:
El apellido de empleado, número de empleado y número de departamento, que son
columnas de la tabla EMPLOYEES
- El número de departamento, nombre de departamento e ID de ubicación, que son
columnas de la tabla DEPARTMENTS
• La cláusula FROM especifica las dos tablas a las que la base de datos debe acceder:
- Tabla EMPLOYEES
- Tabla DEPARTMENTS
• La cláusula WHERE especifica cómo se van a unir las tablas:
e.department_id = d.department_id
Debido a que la columna DEPARTMENT_ID es común a las dos tablas, debe tener como prefijo el
alias de tabla para evitar la ambigüedad. Otras columnas que no estén presentes en las tablas no es
necesario que se cualifiquen según el alias de tabla, pero es recomendable para obtener un mejor
rendimiento.
Nota: al utilizar el icono Execute Statement para ejecutar la consulta, SQL Developer agrega el
sufijo “_1” para diferenciar entre los dos DEPARTMENT_ID.

Oracle Database: Conceptos Fundamentales de SQL I F-10


Recuperación de Registros con Uniones
Igualitarias: Ejemplo
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT d.department_id, d.department_name,


d.location_id, l.city
FROM departments d, locations l
WHERE d.location_id = l.location_id;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Recuperación
R icade Registros
n s fe con Uniones Igualitarias: Ejemplo
En o
s eln trala diapositiva, la tabla LOCATIONS está unida a la tabla DEPARTMENTS mediante
ejemplo-de
n
c
i la columna
noLOCATION_ID, que es la única con el mismo nombre en ambas. Los alias de tabla se
Ed utilizar para cualificar las columnas y evitar ambigüedades.

Oracle Database: Conceptos Fundamentales de SQL I F-11


Condiciones de Búsqueda Adicionales
Mediante el Operador AND
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT d.department_id, d.department_name, l.city


FROM departments d, locations l
WHERE d.location_id = l.location_id
AND d.department_id IN (20, 50);

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Condiciones
R icade Búsqueda
n s fe Adicionales mediante el Operador AND
Además
s tra puede tener diferentes criterios para la cláusula WHERE para restringir las filas
on de nla-unión,
c
i consideración
no
Ed bajo para una o más tablas en la unión. El siguiente ejemplo de la diapositiva limita las
filas de salida a las que tienen un ID de departamento igual a 20 o a 50:
Por ejemplo, para mostrar el número y nombre de departamento del empleado Matos, necesita una
condición adicional en la cláusula WHERE.
SELECT e.last_name, e.department_id,
d.department_name
FROM employees e, departments d
WHERE e.department_id = d.department_id
AND last_name = 'Matos';

Oracle Database: Conceptos Fundamentales de SQL I F-12


Unión de Más de Dos Tablas
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

EMPLOYEES DEPARTMENTS LOCATIONS

s a
) ha
… l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
Para unir n tablas, necesita a r d0un mínimo
S t ud de n–1
condiciones de unión.
( r ichPortejemplo,is para unir tres tablas
hdos
se necesitaneun
i r z mínimo
u s e de uniones.

R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Unión de Más
R icade Dos n s e
fTablas
Puede
s - tranecesite unir más de dos tablas. Por ejemplo, para mostrar el apellido, el nombre
onque anveces
i c no y la ciudad de cada empleado, tiene que unir las tablas EMPLOYEES,
Ed de departamento DEPARTMENTS y LOCATIONS.
SELECT e.last_name, d.department_name, l.city
FROM employees e, departments d, locations l
WHERE e.department_id = d.department_id
AND d.location_id = l.location_id;

Oracle Database: Conceptos Fundamentales de SQL I F-13


Uniones no Igualitarias
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

EMPLOYEES JOB_GRADES

s a
) ha
l ฺ c om
JOB_GRADES define el rango de t m ai
valoreseฺ
de LOWEST_SAL y HIGHEST_SAL @ ho G deu id
cada
… GRADE_LEVEL. Por8lo 4 4tanto,elancolumna
t
GRADE_LEVELrse
a d0puede S t d para
uutilizar
asignarrigrados
( ch tahcada is empleado.
z
ire to us e
m
z Ra nse
o p e© 2010, lOracle
Copyright i c e y/o sus filiales. Todos los derechos reservados.
r d o L rable
Uniones noic a sfe
Igualitarias
R an es una condición de unión que contiene algún operador diferente del
n no-igualitaria
r
Una
s ounión t
d icoperadornodenigualdad.
E La relación entre la tabla EMPLOYEES y JOB_GRADES es un ejemplo de unión no igualitaria. Los
rangos de la columna SALARY en la tabla EMPLOYEES entre los valores en las columnas
LOWEST_SAL y HIGHEST_SAL de la tabla JOB_GRADES. Por lo tanto, se pueden agregar grados
a cada empleado según el salario. La relación se obtiene mediante un operador distinto del de
igualdad (=).

Oracle Database: Conceptos Fundamentales de SQL I F-14


Recuperación de Registros con
Uniones no Igualitarias
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT e.last_name, e.salary, j.grade_level


FROM employees e, job_grades j
WHERE e.salary
BETWEEN j.lowest_sal AND j.highest_sal;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this

i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Recuperación
R icade Registros
n s fe 
con Uniones no Igualitarias
Las n
odiapositiva
n - traejemplo crea una unión no igualitaria para evaluar el grado de salario de un
del
i c noEl salario debe estar entre cualquier par de los rangos de salario bajos y altos.
Ed empleado.
Es importante tener en cuenta que todos los empleados aparecerán sólo una vez al ejecutar esta
consulta. No se repite ningún empleado en la lista. Existen dos motivos por los que se produce este
hecho:
• Ninguna de las filas de la tabla de grados de cargo contiene grados que se solapen. Es decir, el
valor de salario de un empleado sólo puede oscilar entre los valores de salario bajo y alto de
una de las filas de la tabla de grados de salario.
• Todos los salarios de los empleados oscilan entre los límites proporcionados por la tabla de
grados de cargo. Es decir, ningún empleado gana menos que el valor más bajo de la columna
LOWEST_SAL o más que el valor más alto de la columna HIGHEST_SAL.
Nota: se pueden utilizar otras condiciones (como <= y >=), pero BETWEEN es la más simple.
Recuerde especificar primero el valor bajo y, a continuación, el alto, al utilizar BETWEEN. El
servidor Oracle convierte la condición BETWEEN en un par de condiciones AND. Por lo tanto, el uso
de BETWEEN no proporciona ninguna ventaja, se recomienda sólo para la simplicidad lógica.
En el ejemplo de la diapositiva se han especificado los alias de tabla por motivos de rendimiento, no
por una posible ambigüedad.

Oracle Database: Conceptos Fundamentales de SQL I F-15


Devolución de Registros sin Coincidencia Directa
con las Uniones Externas
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

DEPARTMENTS EMPLOYEES

s a
) ha
l ฺ c om
t m ai eฺ

@ ho Guid
8 4 4 ent
a r d0 Stud
No ( r ch ningún
ihay this empleado en el
z
ire departamentous e 190.
m t o
z Ra nse
o p e© 2010, lOracle
Copyright i c e y/o sus filiales. Todos los derechos reservados.
r d o L rable
Devoluciónic aRegistros
de s fe sin Coincidencia Directa con las Uniones Externas
R n
tra una condición de unión, la fila no aparece en el resultado de consultas. Por
onfila non-cumple
Sisuna
c
i ejemplo,nen
o la condición de unión igualitaria de las tablas EMPLOYEES y DEPARTMENTS, el ID de
Ed departamento 190 no aparece porque no hay ningún empleado con ese ID de departamento registrado
en la tabla EMPLOYEES. Igualmente, hay un empleado cuyo DEPARTMENT_ID se ha definido en
NULL, por lo que esta fila tampoco aparecerá en los resultados de la consulta de una unión
igualitaria. Para volver al registro de departamento que no tiene ningún empleado o volver al registro
de empleado que no pertenece a ningún departamento, puede utilizar la unión externa.

Oracle Database: Conceptos Fundamentales de SQL I F-16


Uniones Externas: Sintaxis
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

• Utilice una unión externa para ver las filas que no cumplen
la condición de unión.
• El operador de unión externa es el signo más (+).

SELECT table1.column, table2.column


FROM table1, table2
WHERE table1.column(+) = table2.column; s a
m ) ha
l ฺ c o
SELECT table1.column, table2.column
t m ai eฺ
FROM table1, table2
@ ho Guid
WHERE table1.column = table2.column(+);
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica nSintaxis
Uniones Externas:
R s fe
ra de unión externa en la condición de unión, se pueden devolver las filas que
onutilizanun-toperador
Sisse
i c nooperador es un signo más entre paréntesis (+) y se coloca en el “lado” de la unión que
Ed faltan. El
carece de información. El operador crea una o más filas nulas, a las que se pueden unir una o más
filas de la tabla con información.
En la sintaxis:
table1.column = Es la condición que une (o relaciona) las tablas.
table2.column (+) Es el símbolo de unión externa, que se puede colocar en cualquier lado
de la condición de la cláusula WHERE pero no en ambos lados (coloque
el símbolo de unión externa seguido del nombre de columna en la tabla
sin filas coincidentes).

Oracle Database: Conceptos Fundamentales de SQL I F-17


Uso de Uniones Externas
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT e.last_name, e.department_id, d.department_name


FROM employees e, departments d
WHERE e.department_id(+) = d.department_id ;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
… a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Uso de Uniones
R ica Externas
n s fe
Ens oelnejemplo
n - trala diapositiva se muestran los apellidos de los empleados e ID y nombres de
de
i c no El departamento Contracting no tiene ningún empleado. El valor vacío no se muestra
Ed departamento.
en la salida.
Restricciones de Unión Externa
• La unión externa sólo puede aparecer a un lado de la expresión, el lado al que le falta
información. Devuelve aquellas filas, de una tabla, que no tienen coincidencia directa en la otra
tabla.
• Una condición que incluya una unión externa no puede utilizar el operador IN ni se puede
enlazar a otra condición con el operador OR.
Nota: Oracle no tiene una sintaxis equivalente para soportar FULL OUTER JOIN de la sintaxis de
unión compatible con SQL:1999.

Oracle Database: Conceptos Fundamentales de SQL I F-18


Unión Externa: Otro Ejemplo
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT e.last_name, e.department_id, d.department_name


FROM employees e, departments d
WHERE e.department_id = d.department_id(+) ;

s a
) ha
l ฺ c om
… ai eฺ
t m
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ica Otro
Unión Externa:
R n s fe
Ejemplo
La o
s consulta
n ra de la diapositiva recupera todas las filas de la tabla EMPLOYEES, incluso si
n del-tejemplo
i c no
Ed no hay coincidencia en la tabla DEPARTMENTS.

Oracle Database: Conceptos Fundamentales de SQL I F-19


Unión de una Tabla consigo Misma
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

EMPLOYEES (WORKER) EMPLOYEES (MANAGER)

s a
) ha
l ฺ c om
t m ai eฺ
… … ho Guid
4 @
4 ent
8
d0 Stud
a r
MANAGER_ID en la(tabla r ich WORKER t his es igual a
EMPLOYEE_ID i r z
e en u e
lastabla MANAGER.
am se t o
R
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Unión de una
R icaTablansconsigo
fe Misma
Puede
s - tranecesite unir una tabla consigo misma. Para buscar el nombre de cada gestor del
onque anveces
i c nonecesita unir la tabla EMPLOYEES consigo misma o realizar una autounión. Por ejemplo,
Ed empleado, para buscar el nombre del gestor de Lorentz, necesita:
• Buscar a Lorentz en la tabla EMPLOYEES buscando en la columna LAST_NAME.
• Busque el número de gestor de Lorentz consultando la columna MANAGER_ID. El número de
gestor de Lorentz es 103.
• Busque el nombre del supervisor con un EMPLOYEE_ID de 103 consultando la
columnaLAST_NAME. El número de empleado de Hunold es 103, por lo que Hunold en el
gestor de Lorentz.
Durante este proceso, busca dos veces en la tabla. La primera vez, cuando consulta la tabla para
buscar a Lorentz en la columna LAST_NAME y el valor de MANAGER_ID de 103. La segunda vez,
cuando busca en la columna EMPLOYEE_ID para buscar 103 y en la columna LAST_NAME para
buscar a Hunold.

Oracle Database: Conceptos Fundamentales de SQL I F-20


Autounión: Ejemplo
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

SELECT worker.last_name || ' works for '


|| manager.last_name
FROM employees worker, employees manager
WHERE worker.manager_id = manager.employee_id ;

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
… i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Autounión:ic a sfe
Ejemplo
R an
n de-latrdiapositiva
c s o
El ejemplo
n une la tabla EMPLOYEES consigo misma. Para simular dos tablas en la
i o
Ed En estenejemplo, la cláusula WHERE
cláusula FROM, existen dos alias, llamados worker y manager, para la misma tabla EMPLOYEES.
contiene la unión que significa “donde el número de gestor de un
trabajador coincide con el número de empleado del gestor ”.

Oracle Database: Conceptos Fundamentales de SQL I F-21


Resumen
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

En este apéndice debe haber aprendido a utilizar uniones para


mostrar los datos de varias tablas utilizando:

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
Resumen ica s fe
R n
Hay
s n modos
ovarios n - trade unir tablas.
i c o
Ed Tipos den Uniones • Uniones igualitarias
• Uniones no igualitarias
• Uniones externas
• Autouniones
Productos Cartesianos
Un producto cartesiano da como resultado una visualización de todas las combinaciones de filas.
Para ello debe omitir la cláusula WHERE.
Alias de Tabla
• Los alias de tabla aceleran el acceso a la base de datos.
• Los alias pueden ayudar a mantener el código SQL más pequeño utilizando de esta forma
menos memoria.

Oracle Database: Conceptos Fundamentales de SQL I F-22


Práctica F: Visión General
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

En esta práctica se abordan los siguientes temas:


• Unión de tablas con una unión igualitaria
• Realización de uniones externas y autouniones
• Adición de condiciones

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p e©z2010, lOracle
Copyright i c eny/o sus filiales. Todos los derechos reservados.
r d o L rable
ca nGeneral
Práctica F: iVisión
R s fe
Esta
s n
opráctica
n - tradestinada a proporcionarle experiencia práctica en la extracción de datos desde más
está
i c no utilizando sintaxis de unión en Oracle.
Ed de una tabla

Oracle Database: Conceptos Fundamentales de SQL I F-23


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
Índice
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed
A
alias 1-5, 1-9, 1-17, 1-18, 1-20, 1-21, 1-29, 2-5, 2-6, 2-8,
2-23, 2-24, 2-38, 4-25, 5-14, 5-27, 6-7, 6-14, 6-16, 6-24, 6-36,
8-28, 10-34, 11-8, 11-10, 11-12, C-8, F-8, F-10, F-11, F-15, F-21,
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

F-22
ALL 2-36, 5-6, 7-3, 7-5, 7-9, 7-16, 7-17, 7-19, 7-21, 7-22,
8-3, 8-4, 8-5, 8-6, 8-7, 8-12, 8-16, 8-17, 8-18, 8-21, 8-24,
8-27, 8-29, 8-30
AND 2-3, 2-8, 2-10, 2-15, 2-16, 2-18, 2-19, 2-20, 2-21, 2-22,
2-26, 2-34, 2-38, 6-18, 6-24, 7-11, 7-18, 7-19, 9-44, F-12, F-13,
s a
) ha
F-15

l ฺ c om
ANY 7-3, 7-5, 7-9, 7-16, 7-17, 7-18, 7-19, 7-21, 7-22, 10-39,
11-20, 11-32, 11-39
t m ai eฺ
atributos i-22, i-23, i-24
@ ho Guid
4
autounión 6-2, 6-20, 6-21, F-2, F-20
8 4 ent
r d0 Stud
AVG 5-3, 5-5, 5-7, 5-8, 5-12, 5-15, 5-25, 5-28
a
B ( r ich this
i r z use
e2-19,
BETWEEN 2-3, 2-8, 2-10, 2-12, 2-18, m e to2-20, 2-22, 2-26,
2-34, 2-37, 2-38, 6-24,
a
R ns
F-15
p e z c e
C o
L ble l i
r d o ra 4-27, 4-32, 4-36, 4-37, 4-38, 4-39,
CASE 3-7,a4-3, 4-10,e4-23,
i c
R 4-44, s f
o n 4-40,
- t r an4-45, 5-6
s
ic CHECK n 10-3, 10-7, 10-12, 10-16, 10-17, 10-28, 10-29, 10-32, 10-35,
o9-8,
Ed n
10-38, 11-8, 11-9, 11-17
cláusula 1-5, 1-7, 1-11, 1-20, 1-24, 2-3, 2-4, 2-5, 2-6,
2-7, 2-8, 2-9, 2-11, 2-15, 2-19, 2-22, 2-23, 2-24, 2-25, 2-26,
2-27, 2-28, 2-31, 2-32, 2-34, 2-37, 2-38, 2-39, 3-12, 3-17, 4-38,
4-39, 5-2, 5-9, 5-13, 5-14, 5-15, 5-16, 5-18, 5-19, 5-20, 5-21,
5-22, 5-23, 5-26, 5-27, 5-28, 5-29, 6-6, 6-7, 6-9, 6-10, 6-11,
6-14, 6-15, 6-16, 6-17, 6-18, 6-21, 6-34, 6-36, 7-2, 7-5, 7-13,
7-14, 7-15, 7-23, 7-25, 8-3, 8-5, 8-6, 8-7, 8-12, 8-13, 8-15,
8-17, 8-18, 8-21, 8-24, 8-27, 8-28, 8-29, 8-30, 9-6, 9-7, 9-8,
9-12, 9-15, 9-16, 9-17, 9-22, 9-43, 9-44, 9-47, 10-14, 10-33, 10-39,
11-12, 11-14, 11-15, 11-16, 11-17, 11-25, 11-28, 11-38, F-4, F-7, F-8,
F-10, F-12, F-17, F-21, F-22

Oracle Database: Conceptos Fundamentales de SQL I Índice-2


C
COALESCE 3-7, 4-3, 4-10, 4-23, 4-27, 4-28, 4-33, 4-34, 4-35,
4-36, 4-44, 5-6
comando 1-8, 1-26, 1-27, 2-27, 2-28, 2-29, 2-33, 2-35, 2-36,
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

4-22, 9-8, 9-31, 9-32, 9-43, 10-11, 10-34, 10-37, 11-9, 11-13, 11-39,
C-11, C-22, C-31, D-6, D-7, D-9, D-10, D-11, D-12, D-14, D-15,
D-16, D-17, E-7
condiciones 1-23, 2-3, 2-8, 2-11, 2-12, 2-14, 2-15, 2-16, 2-19,
2-21, 2-22, 2-26, 2-27, 2-34, 2-38, 6-15, 6-18, 6-24, 6-37, 7-5,
7-7, 7-11, 7-22, 9-27, 10-28, 11-15, F-7, F-13, F-15, F-23
s a
) ha
consulta i-30, 1-4, 1-8, 1-17, 1-18, 1-24, 2-2, 2-5, 2-23,

l ฺ c om
2-25, 2-27, 2-31, 2-33, 3-6, 3-26, 3-33, 4-21, 4-35, 5-15, 6-7,

t m ai eฺ
6-14, 6-16, 6-20, 6-24, 6-28, 6-29, 6-30, 7-4, 7-5, 7-6, 7-11,
ho Guid
7-12, 7-13, 7-14, 7-15, 7-17, 7-22, 7-24, 7-25, 7-26, 8-5, 8-6,
@
4 4 ent
8-13, 8-17, 8-19, 8-20, 8-22, 8-25, 8-26, 8-28, 8-29, 8-30, 9-23,
8
r d0 Stud
9-33, 9-44, 9-47, 10-28, 10-42, 11-8, 11-29, 11-36, 11-37, 11-38, C-18,
a
r ich this
C-28, D-3, D-5, D-13, D-16, D-17, F-8, F-10, F-15, F-16, F-19,
(
i r ez use
F-20
R am se to
COUNT 5-3, 5-5, 5-9, 5-12, 5-19, 5-25, 5-28
o p ez licen CURRENT_DATE 3-24, 9-9
r d o L rable CURRVAL 10-10, 10-28, 11-3, 11-22, 11-27, 11-28, 11-29, 11-33, 11-40
D R ica nsfe
s on i-17
n - tra
i c DBMS
no 3-7, 4-3, 4-10, 4-23, 4-27, 4-36, 4-37, 4-39, 4-40, 4-41,
Ed DECODE
4-42, 4-44, 4-45, 5-6
DEFAULT 10-3, 10-7, 10-8, 10-10, 10-11, 10-12, 10-16, 10-19, 10-32,
10-35, 10-38, 11-28
DELETE i-31, 9-3, 9-13, 9-19, 9-21, 9-22, 9-23, 9-24, 9-25, 9-29,
9-35, 9-36, 9-37, 9-39, 9-40, 9-42, 9-46, 9-47, 10-27, 10-31, 11-7,
11-19, 11-28, D-17
DESCRIBE 1-3, 1-10, 1-16, 1-19, 1-25, 1-26, 1-27, 8-9, 8-10,
9-7, 9-8, 10-11, 10-34, 11-9, 11-13, B-4, B-5, B-6, B-7, B-8,
B-9, B-10, C-11, D-7, D-8
DISTINCT 1-3, 1-5, 1-10, 1-16, 1-19, 1-24, 1-25, 1-29, 2-5,
2-38, 5-3, 5-6, 5-10, 5-12, 5-25, 11-14, 11-15, 11-16, 11-28

Oracle Database: Conceptos Fundamentales de SQL I Índice-3


D
DUAL 3-17, 3-18, 3-24, 3-32
E
esquema i-2, i-4, i-34, i-40, 10-2, 10-5, 10-6, 10-9, 10-29,
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

10-41, 11-35, 11-42, C-3, C-5, C-8, C-10, C-13, E-5, E-6
expresión 1-5, 1-11, 1-12, 1-13, 1-15, 1-20, 1-29, 2-3, 2-8,
2-19, 2-22, 2-23, 2-26, 2-34, 3-6, 3-13, 3-17, 3-18, 3-31, 4-5,
4-6, 4-25, 4-29, 4-30, 4-31, 4-32, 4-33, 4-37, 4-38, 4-39, 4-40,
4-44, 5-9, 5-19, 10-10, 10-34, 11-13, 11-28, 11-38, F-18
F
s a
fecha i-22, 1-9, 1-11, 1-20, 1-21, 2-7, 2-24, 2-31, 3-2, 3-3, ) ha
c om
3-7, 3-8, 3-15, 3-17, 3-18, 3-20, 3-21, 3-22, 3-23, 3-24, 3-25,
l ฺ
t m ai eฺ
3-26, 3-27, 3-28, 3-29, 3-30, 3-32, 3-33, 4-5, 4-11, 4-14, 4-16,
@ ho Guid
4-20, 4-21, 4-22, 4-25, 4-29, 4-43, 4-44, 5-8, 8-8, 9-7, 9-9,
8 4 4 ent
9-10, 10-11, 10-13, 10-15
a r d0 Stud
( r ich this
funciones i-2, i-4, i-9, i-10, i-11, i-13, i-16, i-39, 2-5,

i r ez use
2-7, 3-2, 3-4, 3-5, 3-6, 3-7, 3-9, 3-10, 3-11, 3-13, 3-16,

R am se to
3-17, 3-18, 3-24, 3-28, 3-30, 3-31, 3-32, 3-33, 4-2, 4-4, 4-7,

o p ez licen 4-9, 4-20, 4-24, 4-28, 4-44, 4-45, 5-2, 5-3, 5-4, 5-5, 5-6,

r d o L rable 5-7, 5-8, 5-11, 5-12, 5-13, 5-14, 5-15, 5-19, 5-20, 5-22, 5-25,

R i ca nsfe 5-26, 5-27, 5-28, 5-29, 7-2, 7-25, 8-25, 9-9, 10-10, 10-18, 10-28,

o t r a C-2, C-6, C-14, C-24, C-26, E-2, E-3, E-15, E-18


n 11-7, -11-13,
s
ic función n 3-6, 3-7, 3-12, 3-17, 3-18, 3-19, 3-23, 3-24,
o3-4,
Ed n
3-26, 3-29, 3-32, 4-11, 4-17, 4-20, 4-25, 4-26, 4-29, 4-30, 4-31,
4-32, 4-33, 4-34, 4-37, 4-39, 4-40, 4-42, 4-43, 4-44, 4-45, 5-3,
5-6, 5-9, 5-11, 5-12, 5-14, 5-15, 5-16, 5-18, 5-19, 5-22, 5-23,
5-25, 5-27, 7-12, 8-25, 9-9, 9-10, 9-12, 10-10, 10-33, 11-13, C-6,
C-23, C-24, C-25, C-26, D-17, E-8
H
HAVING 5-2, 5-3, 5-12, 5-20, 5-21, 5-22, 5-23, 5-24, 5-25, 5-28,
5-29, 7-3, 7-5, 7-9, 7-13, 7-16, 7-21, 7-25, 11-28
I
icono 1-6, 1-8, 2-36, 6-16, 9-4, 10-10, 10-42, 11-8, C-5, C-15,
C-17, C-19, C-20, C-21, C-22, C-26, E-5, E-7, F-10

Oracle Database: Conceptos Fundamentales de SQL I Índice-4


I
IN 2-3, 2-11, 2-18, 2-19, 2-20, 2-22, 2-26, 2-34, 2-37, 2-38,
4-31, 6-10, 7-5, 7-14, 7-16, 7-17, 7-18, 7-19, 7-22, 7-23, 7-25,
9-22, 9-35, F-12, F-18
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

INSERT i-31, 3-23, 9-3, 9-6, 9-7, 9-8, 9-9, 9-10, 9-11, 9-12,
9-13, 9-19, 9-25, 9-29, 9-30, 9-35, 9-39, 9-40, 9-42, 9-47, 10-8,
10-10, 10-11, 10-19, 10-22, 10-24, 10-25, 11-7, 11-17, 11-28, 11-29, D-17
INTERSECT 8-3, 8-4, 8-5, 8-7, 8-12, 8-18, 8-19, 8-20, 8-21,
8-24, 8-27, 8-30, 8-31
J a
s
Java i-12, C-4, C-8, E-3, E-12, E-14, E-15, E-16
) ha
L l ฺ c om
LENGTH 3-9, 3-10, 3-13, 3-14, 3-32 t m ai eฺ
LIKE 2-3, 2-8, 2-12, 2-13, 2-16, 2-17, 2-18, 2-19, 2-20, 2-22, @h
o uid
4 4 n t G
2-26, 2-34, 2-37, 2-38, 3-30, 5-7, 5-24, 9-12, 9-230
d 8 u de
literal 1-14, 1-21, 1-22, 1-23, 3-13, 4-11, 4-31, 4-32,
r
ha 4-38, S t
( r i c t h i s
8-26, 10-10
r e z s e
LPAD 3-9, 3-13
a mi e to u
z R ns
M
o p e l i c e
MAX 5-3, 5-5, 5-7,
r d o L5-8,ra5-12,
ble5-25, 5-28
MIN 5-3,ic a 5-7,s5-8,
5-5, f e 5-12, 5-25, 5-28, 7-12
R
n 8-3,-t8-4,
MINUS r an8-5, 8-7, 8-12, 8-18, 8-21, 8-22, 8-23, 8-24,
s o
d ic n8-27, on 8-30, 8-31
E MOD 3-16, 3-19, 3-32
N
NEXTVAL 10-10, 10-28, 11-3, 11-22, 11-27, 11-28, 11-33, 11-40
nomenclatura 10-3, 10-5, 10-7, 10-12, 10-16, 10-18, 10-32, 10-35, 10-38
NOT 1-14, 1-26, 1-27, 2-3, 2-14, 2-15, 2-18, 2-19, 2-20, 2-22,
2-26, 2-34, 2-38, 5-24, 7-19, 7-20, 7-22, 7-23, 9-8, 10-3, 10-7,
10-12, 10-16, 10-17, 10-19, 10-20, 10-21, 10-22, 10-23, 10-26, 10-29, 10-32,
10-33, 10-35, 10-38, 11-16, D-7, D-8

Oracle Database: Conceptos Fundamentales de SQL I Índice-5


N
NULL 1-3, 1-10, 1-14, 1-16, 1-19, 1-20, 1-25, 1-26, 1-27, 2-3,
2-8, 2-14, 2-18, 2-19, 2-20, 2-22, 2-26, 2-34, 2-37, 2-38, 4-32,
4-38, 4-39, 5-3, 5-12, 5-18, 5-25, 7-23, 8-13, 9-8, 9-9, 9-16,
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

9-35, 10-3, 10-7, 10-10, 10-12, 10-16, 10-17, 10-19, 10-20, 10-21, 10-22,
10-23, 10-25, 10-26, 10-27, 10-29, 10-32, 10-33, 10-35, 10-38, 11-16, D-7,
D-8, E-10, F-16
NULLIF 3-7, 4-3, 4-10, 4-23, 4-27, 4-28, 4-32, 4-36, 4-44
NVL2 3-7, 4-3, 4-10, 4-23, 4-27, 4-28, 4-31, 4-36, 4-44, 5-6
NVL 3-7, 4-3, 4-10, 4-23, 4-27, 4-28, 4-29, 4-30, 4-33, 4-36,
s a
) ha
4-44, 5-6, 5-11
O
l ฺ c om
OLTP i-11, i-16
t m ai eฺ
ho Guid
ON 2-36, 6-3, 6-5, 6-6, 6-8, 6-15, 6-16, 6-17, 6-18, 6-19,
@
8 4 4 ent
6-21, 6-22, 6-24, 6-25, 6-27, 6-28, 6-29, 6-30, 6-31, 9-31, 10-27,
a r d0 Stud
11-13, 11-37, D-15, D-17
( r ich this
opción i-24, 2-13, 9-31, 10-10, 10-33, 11-8, 11-9, 11-12, 11-18, 11-25,
i r ez use
11-26, 11-31, 11-32, C-13, C-19, C-26
R am se to
operador 1-3, 1-10, 1-12, 1-16, 1-19, 1-20, 1-23, 1-25, 2-5,
o p ez licen 2-10, 2-11, 2-12, 2-14, 2-18, 4-30, 6-23, 7-3, 7-7, 7-9, 7-10,
r d o L rable 7-14, 7-16, 7-17, 7-18, 7-19, 7-20, 7-21, 7-22, 7-25, 8-2, 8-4,
R ica nsfe 8-5, 8-6, 8-13, 8-14, 8-16, 8-17, 8-19, 8-22, 8-25, 8-26, 8-29,
c s on n-tra 8-30, 8-31, F-14, F-17, F-18
i no
Ed OR 2-3, 2-11, 2-15, 2-17, 2-19, 2-20, 2-21, 2-22, 2-26, 2-34,
2-38, 11-8, 11-9, 11-10, 11-12, 11-13, 11-17, 11-19, F-18
ORDBMS i-2, i-39
orden i-27, 1-7, 1-13, 2-2, 2-11, 2-20, 2-23, 2-24, 2-25, 2-33,
2-39, 5-15, 5-18, 5-27, 5-28, 8-2, 8-4, 8-5, 8-6, 8-13, 8-15,
8-19, 8-28, 9-7, 9-8, 11-12
ordenación 2-23, 2-24, 2-25
P
pseudocolumnas 10-28, 11-27, 11-28

Oracle Database: Conceptos Fundamentales de SQL I Índice-6


Q
q 1-23
R
RDBMS i-2, i-18, i-25, i-27, i-39, 9-43
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

REFERENCES 10-26, 10-27, 10-29


REPLACE 3-9, 3-13, 11-8, 11-9, 11-10, 11-12, 11-13, 11-17, 11-19,
D-16
restricciones i-16, i-39, 1-14, 6-10, 9-4, 9-8, 9-24, 10-2,
10-3, 10-7, 10-12, 10-14, 10-16, 10-17, 10-18, 10-19, 10-20, 10-21, 10-22,
10-23, 10-26, 10-28, 10-30, 10-32, 10-33, 10-35, 10-38, 10-40, 10-41, 11-17, a
s
11-39, C-10, E-6
) ha
l ฺ c om
restricción 1-26, 2-4, 9-4, 9-8, 9-20, 9-24, 10-17, 10-18, 10-19,

t m ai eฺ
10-20, 10-21, 10-22, 10-23, 10-24, 10-25, 10-26, 10-27, 10-28, 10-30, 10-31,
ho Guid
10-33, 11-8, 11-9, 11-17, 11-19, 11-21, 11-34, 11-36, 11-38, 11-44
@
8 4 4 ent
ROUND 3-16, 3-17, 3-18, 3-28, 3-30, 3-32, 4-26
RPAD 3-9, 3-13 a r d0 Stud
( r i ch this
S
i r e z use
R am11-22,
secuencias 2-24, 10-9, 11-2, 11-3,
e to 11-24, 11-25, 11-30,
11-23,
11-31, 11-33, 11-39, z
p e c e ns 11-45, 11-46
11-40, 11-42,
Lo ble li
selección C-6, E-12
o
i c ard sfera
n R ran
i c s o
o n -t
Ed n

Oracle Database: Conceptos Fundamentales de SQL I Índice-7


S
SELECT i-4, i-5, i-30, i-31, 1-1, 1-2, 1-3, 1-4, 1-5, 1-6,
1-7, 1-9, 1-10, 1-12, 1-13, 1-14, 1-15, 1-16, 1-17, 1-18, 1-19,
1-20, 1-21, 1-22, 1-23, 1-24, 1-25, 1-28, 1-29, 1-30, 2-5, 2-6,
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

2-7, 2-9, 2-10, 2-11, 2-12, 2-13, 2-14, 2-16, 2-17, 2-18, 2-21,
2-23, 2-24, 2-25, 2-28, 2-29, 2-31, 2-32, 2-33, 2-35, 2-36, 2-38,
2-39, 3-2, 3-6, 3-11, 3-12, 3-14, 3-17, 3-18, 3-19, 3-21, 3-24,
3-26, 3-29, 3-30, 4-2, 4-11, 4-16, 4-19, 4-21, 4-22, 4-25, 4-26,
4-30, 4-31, 4-32, 4-34, 4-35, 4-39, 4-41, 4-42, 4-44, 5-6, 5-7,
5-8, 5-9, 5-10, 5-11, 5-14, 5-15, 5-16, 5-17, 5-18, 5-19, 5-20,
s a
) ha
5-22, 5-23, 5-24, 5-26, 5-27, 5-28, 6-2, 6-6, 6-7, 6-10, 6-13,

l ฺ c om
6-14, 6-16, 6-17, 6-18, 6-21, 6-24, 6-28, 6-29, 6-30, 6-34, 7-2,

t m ai eฺ
7-5, 7-6, 7-8, 7-10, 7-11, 7-12, 7-13, 7-14, 7-15, 7-17, 7-18,
ho Guid
7-19, 7-20, 7-22, 7-23, 7-25, 7-26, 8-3, 8-5, 8-6, 8-7, 8-10,
@
4 4 ent
8-11, 8-12, 8-13, 8-14, 8-15, 8-17, 8-18, 8-19, 8-20, 8-21, 8-22,
8
r d0 Stud
8-23, 8-24, 8-25, 8-26, 8-27, 8-28, 8-29, 8-30, 9-3, 9-9, 9-12,
a
( r ich this
9-13, 9-16, 9-17, 9-18, 9-19, 9-22, 9-23, 9-25, 9-33, 9-37, 9-39,
i r ez use
9-40, 9-41, 9-42, 9-43, 9-44, 9-45, 9-47, 10-9, 10-33, 10-34, 10-37,
R am se to 10-42, 11-5, 11-8, 11-9, 11-10, 11-11, 11-12, 11-13, 11-17, 11-19, 11-28,
o p ez licen 11-29, B-4, B-5, B-6, B-7, B-8, B-9, B-10, C-25, D-2, D-11,
r d o L rable D-12, D-14, D-17, F-2, F-5, F-7, F-8, F-10, F-11, F-12, F-13,
R ica nsfe F-15, F-17, F-18, F-19, F-21

c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I Índice-8


S
sentencia i-4, i-30, 1-2, 1-3, 1-4, 1-5, 1-6, 1-7, 1-8,
1-10, 1-11, 1-12, 1-16, 1-18, 1-19, 1-21, 1-22, 1-25, 1-29, 2-6,
2-10, 2-12, 2-13, 2-14, 2-21, 2-23, 2-27, 2-28, 2-29, 2-30, 2-31,
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

2-32, 2-35, 2-36, 2-38, 3-12, 3-14, 4-2, 4-16, 4-25, 4-37, 4-38,
4-39, 4-40, 4-41, 4-44, 5-9, 5-15, 5-16, 5-17, 5-18, 5-19, 5-20,
5-28, 6-7, 6-14, 6-15, 7-2, 7-5, 7-8, 7-10, 7-11, 7-13, 7-14,
7-15, 7-22, 7-25, 8-4, 8-5, 8-6, 8-20, 8-22, 8-26, 8-28, 8-30,
9-2, 9-3, 9-4, 9-6, 9-8, 9-11, 9-12, 9-13, 9-15, 9-16, 9-17,
9-19, 9-21, 9-22, 9-24, 9-25, 9-26, 9-27, 9-29, 9-30, 9-31, 9-33,
s a
) ha
9-34, 9-35, 9-36, 9-37, 9-38, 9-39, 9-40, 9-41, 9-42, 9-43, 9-44,

l ฺ c om
9-47, 10-8, 10-10, 10-11, 10-19, 10-29, 10-31, 10-33, 10-36, 10-37, 10-39,

t m ai eฺ
10-41, 10-42, 11-5, 11-6, 11-8, 11-10, 11-13, 11-20, 11-25, 11-28, 11-29,
ho Guid
11-30, 11-31, 11-32, 11-37, 11-39, 11-43, C-13, C-16, C-19, C-23, C-25,
@
4 4 ent
C-26, C-28, D-3, D-5, E-7, F-7, F-8
8
r d0 Stud
sinónimo i-24, 1-24, 1-26, 7-18, 11-2, 11-42, 11-43, 11-46, D-7
a
r ich this
subconsulta 7-3, 7-4, 7-5, 7-7, 7-9, 7-10, 7-11, 7-12, 7-13,
(
i r ez use
7-14, 7-15, 7-16, 7-17, 7-18, 7-19, 7-20, 7-21, 7-22, 7-23, 7-24,
R am se to 7-25, 9-12, 9-15, 9-23, 10-3, 10-7, 10-12, 10-14, 10-33, 10-35, 10-38,
o p ez licen 10-41, 11-8, 11-9, 11-10, 11-12, 11-28
r d o L rable SUBSTR 3-9, 3-10, 3-13, 3-32, 4-25
R ica nsfe SYSDATE 3-23, 3-24, 3-26, 3-29, 3-30, 3-32, 9-9, 10-10, 10-11,

c s on n-tra 10-28
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I Índice-9


T
tabla i-19, i-20, i-25, i-27, i-28, i-30, i-34, 1-4, 1-5, 1-6,
1-7, 1-12, 1-14, 1-24, 1-26, 1-27, 1-29, 2-7, 2-9, 2-10, 2-11,
2-12, 2-16, 2-17, 2-18, 2-20, 2-24, 2-25, 2-28, 2-32, 3-12, 3-17,
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

3-22, 3-23, 3-24, 3-32, 4-32, 5-2, 5-4, 5-5, 5-9, 5-10, 5-11,
5-13, 5-14, 5-15, 5-17, 5-18, 6-2, 6-4, 6-6, 6-7, 6-10, 6-12,
6-14, 6-16, 6-20, 6-21, 6-23, 6-24, 6-26, 6-27, 6-28, 6-29, 6-30,
6-32, 6-33, 6-34, 6-36, 6-37, 7-5, 7-20, 8-8, 8-20, 8-23, 8-25,
8-26, 9-2, 9-3, 9-4, 9-5, 9-6, 9-7, 9-9, 9-10, 9-11, 9-12,
9-13, 9-14, 9-15, 9-16, 9-18, 9-19, 9-20, 9-21, 9-22, 9-23, 9-24,
s a
) ha
9-25, 9-35, 9-37, 9-39, 9-41, 9-42, 9-43, 9-44, 9-47, 9-48, 10-2,

l ฺ c om
10-3, 10-4, 10-5, 10-7, 10-8, 10-9, 10-10, 10-11, 10-12, 10-13, 10-14,

t m ai eฺ
10-17, 10-18, 10-19, 10-20, 10-21, 10-22, 10-23, 10-24, 10-25, 10-26, 10-27,
ho Guid
10-28, 10-29, 10-30, 10-31, 10-33, 10-34, 10-35, 10-36, 10-37, 10-38, 10-39,
@
4 4 ent
10-40, 10-41, 10-42, 11-5, 11-6, 11-7, 11-11, 11-16, 11-26, 11-29, 11-30,
8
r d0 Stud
11-35, 11-36, 11-37, 11-38, 11-39, 11-41, 11-42, 11-43, 11-44, C-10, C-11,
a
( r ich this
C-13, C-14, C-15, D-4, D-5, D-7, D-8, D-12, D-13, E-6, F-2,
i r ez use
F-3, F-4, F-5, F-7, F-8, F-9, F-10, F-11, F-14, F-15, F-16,
R am se to F-17, F-18, F-19, F-20, F-21, F-22, F-23
o p ez licen TO_CHAR 4-2, 4-3, 4-7, 4-8, 4-9, 4-10, 4-11, 4-16, 4-17,
r d o L rable 4-18, 4-19, 4-22, 4-23, 4-26, 4-27, 4-34, 4-36, 4-44, 4-45, 8-25
R ica nsfe TO_DATE 4-2, 4-3, 4-7, 4-8, 4-9, 4-10, 4-20, 4-21, 4-22,

c s on n-tra 4-23, 4-27, 4-36, 4-44, 4-45, 9-10


i no
Ed TO_NUMBER 4-2, 4-3, 4-7, 4-8, 4-9, 4-10, 4-20, 4-21, 4-23,
4-27, 4-36, 4-43, 4-44
transacciones i-11, 9-2, 9-3, 9-4, 9-13, 9-19, 9-25, 9-26,
9-29, 9-38, 9-39, 9-42, 9-48, 10-39
TRIM 3-9, 3-10, 3-13
TRUNC 3-16, 3-18, 3-28, 3-30, 3-32
U
UNION 8-3, 8-5, 8-6, 8-7, 8-12, 8-13, 8-14, 8-15, 8-16, 8-17,
8-18, 8-21, 8-24, 8-25, 8-26, 8-27, 8-28, 8-29, 8-30, 8-31
UNIQUE 1-24, 10-3, 10-7, 10-12, 10-16, 10-17, 10-22, 10-23, 10-29, 10-32,
10-35, 10-38, 11-36, 11-37, 11-44

Oracle Database: Conceptos Fundamentales de SQL I Índice-10


U
UPDATE i-31, 9-3, 9-13, 9-15, 9-16, 9-17, 9-18, 9-19, 9-25, 9-29,
9-30, 9-35, 9-39, 9-40, 9-41, 9-42, 9-43, 9-44, 9-45, 9-47, 10-30,
10-37, 11-7, 11-17, 11-28, D-17
Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

USING 6-3, 6-5, 6-6, 6-8, 6-11, 6-13, 6-14, 6-17, 6-19, 6-22,
6-25, 6-27, 6-31, 9-44
V
VARIANCE 5-5, 5-8, 5-28
VERIFY 2-3, 2-19, 2-22, 2-26, 2-34, 2-36
vistas 10-9, 10-11, 10-39, 11-2, 11-3, 11-4, 11-5, 11-6, 11-7, 11-14, a
s
11-17, 11-20, 11-21, 11-22, 11-33, 11-39, 11-40, 11-42, 11-45, C-10, E-6,
) ha
E-13
l ฺ c om
W t m ai eฺ
WHERE 2-3, 2-4, 2-5, 2-6, 2-7, 2-8, 2-9, 2-10, 2-11, 2-12, @ ho Guid
2-13, 2-14, 2-15, 2-16, 2-17, 2-18, 2-19, 2-21, 2-22, 8 4 4 2-26,
2-23, e n t
a r d0 2-38,
S t d
u2-39,
2-27, 2-28, 2-29, 2-31, 2-32, 2-34, 2-35, 2-36,
( r i ch this2-37,
3-6, 3-12, 3-14, 3-19, 3-21, 3-26, 3-29,
i r e z 3-30,u s e4-11, 4-19, 4-21,
R am 5-9,
4-22, 4-25, 4-31, 4-42, 5-6, 5-7,
e to 5-15, 5-18, 5-20,
5-14,
5-21, 5-22, 5-24, 5-27,
p e ns 6-14, 6-15, 6-18, 6-36, 7-2,
z 5-28,ce6-10,
o 7-12,
7-5, 7-6, 7-10,L7-11, l e li7-13, 7-14, 7-15, 7-17, 7-18, 7-19,
7-20, a
7-22,
o
rd 7-23, r ab 8-5, 9-9, 9-12, 9-15, 9-16, 9-17, 9-18,
7-25,
c f e
n Ri 9-22,
9-21, r a n s
9-23, 9-35, 9-37, 9-41, 9-43, 9-44, 9-45, 10-30, 10-31,
i c so 10-34,
o n -t11-9, 11-10, 11-12, 11-17, 11-19, 11-38, F-4, F-7, F-10, F-11,
Ed n
F-12, F-13, F-15, F-17, F-18, F-19, F-21, F-22
X
XML i-9, i-14, i-39, C-7, C-9, C-27, E-3, E-12

Oracle Database: Conceptos Fundamentales de SQL I Índice-11


Unauthorized reproduction or distribution prohibitedฺ Copyright© 2015, Oracle and/or its affiliatesฺ

s a
) ha
l ฺ c om
t m ai eฺ
@ ho Guid
8 4 4 ent
a r d0 Stud
( r ich this
i r ez use
R am se to
o p ez licen
r d o L rable
R ica nsfe
c s on n-tra
i no
Ed

Oracle Database: Conceptos Fundamentales de SQL I Índice-12

También podría gustarte