Está en la página 1de 64

Ficheros y Bases de Datos

Tema 3
Lenguaje SQL

Lenguaje SQL 1

Introducción a SQL
‹ Structured Query Language (SQL)
‹ Lenguaje declarativo de acceso a bases de datos que combina
construcciones del álgebra relacional y el cálculo relacional.
‹ Originalmente desarrollado en los '70 por IBM en su Research
Laboratory de San José a partir del cálculo de predicados creado por
Codd.
‹ Lenguaje estándar de facto en los SGBD comerciales
‹ Estándares:
„ SEQUEL(Structured English QUEry Language), IBM 1976
„ SQL-86 (ANSI SQL)
„ SQL-89 (SQL1)
„ SQL-92 (SQL2), gran revisión del estándar
„ SQL:1999 (SQL3), Añade disparadores, algo de OO, ...
„ SQL:2003. Añade XML, secuencias y columnas autonuméricas.

Lenguaje SQL 2
Características de SQL
‹ El Lenguage de Definición de Datos (LDD)
„ Proporciona comandos para la creación, borrado y modificación de
esquemas relacionales
‹ El Lenguaje de Manipulación de Datos (LMD)
„ Basado en el álgebra relacional y el cálculo relacional permite realizar
consultas y adicionalmente insertar, borrar y actualizar de tuplas
„ Ejecutado en una consola interactiva
„ Embebido dentro de un lenguaje de programación de propósito general
‹ Definición de vistas
‹ Autorización
„ Definición de usuarios y privilegios
‹ Integridad de datos
‹ Control de Transacciones

Lenguaje SQL 3

Estructura de la sentencia SELECT

SELECT A1, …, An -Describe la salida deseada con:


•Nombres de columnas
•Expresiones aritméticas
•Literales
•Funciones escalares
•Funciones de columna
FROM T1, …, Tn - Nombres de las tablas / vistas
WHERE P - Condiciones de selección de filas

GROUP BY Ai1, …, Ain - Nombre de las columnas


HAVING Q - Condiciones de selección de grupo

ORDER BY Aj1, …, Ajn - Nombres de columnas

Lenguaje SQL 4
Estructura básica de la sentencia SELECT

‹ Consta de tres cláusulas: SELECT, FROM y WHERE.


„ SELECT corresponde a la operación de proyección del álgebra
relacional.
z La lista de los atributos que se incluirán en el resultado de una consulta.
„ FROM corresponde al producto cartesiano del álgebra relacional.
z Especifica las relaciones que se van a usar como origen en el proceso de
la consulta.
„ WHERE corresponde al predicado de selección del álgebra relacional.
z Consta de un predicado que implica atributos de las relaciones de la
cláusula FROM.

Lenguaje SQL 5

Estructura básica de la sentencia SELECT

‹ Una consulta SQL tiene la forma:


SELECT A1, ..., An /* Lista de atributos */
FROM R1, ..., Rm /* Lista de relaciones */
WHERE P; /* Condición. Cláusula OPCIONAL */
„ Es posible que existan el mismo nombre de atributo en dos relaciones
distintas.
„ Se añade "NOMBRE_RELACION." antes del nombre para desambiguar.
‹ Es equivalente a la siguiente expresión del álgebra relacional:
ΠA1,A2,...,An ( σP ( R1 × R2 × … × Rm ) )
‹ El orden de ejecución de la expresión anterior es el mismo que el de la
consulta SQL.
‹ ADVERTENCIA: la selección del AR y el SELECT de SQL no
funcionan igual.
„ El resultado de una consulta SELECT puede tener tuplas repetidas.

Lenguaje SQL 6
Proyección de algunas columnas

SELECT DEPTNO, DEPTNAME, ADMRDEPT


FROM DEPARTMENT

DEPTNO DEPTNAME ADMRDEPT


A00 SPIFFY COMPUTER SERVICE DIV. A00
B01 PLANNING A00
C01 INFORMATION CENTER A00
D01 DEVELOPMENTCENTER A00
D11 MANUFACTURING SYSTEMS D01
D21 ADMINISTRATION SYSTEMS D01
E01 SUPPORT SERVICES A00
E11 OPERATIONS E01
E21 SOFTWARE SUPPORT E01

Lenguaje SQL 7

Eliminación de filas duplicadas

‹ SQL permite duplicados debido a la gran cantidad de tiempo


que puede llevar eliminarlos
‹ Para eliminar las tuplas repetidas se utiliza la cláusula
DISTINCT.
‹ También es posible pedir explícitamente la inclusión de
tuplas repetidas mediante el uso de la cláusula ALL.
SELECT ADMRDEPT SELECT DISTINCT ADMRDEPT
FROM DEPARTMENT FROM DEPARTMENT
ADMRDEPT SELECT ALL ADMRDEPT ADMRDEPT
A00 FROM DEPARTMENT A00
A00 D01
A00 E01
A00
D01
D01
A00
E01
E01 Lenguaje SQL 8
Eliminación de filas duplicadas

‹ ¿Qué trabajos realiza cada departamento?


SELECT DISTINCT WORKDEPT, JOB
FROM EMPLOYEE

WORKDEPT JOB
A00 CLERK
A00 PRES
A00 SALESREP
B01 MANAGER
C01 ANALYST
C01 MANAGER
D11 DESIGNER
D11 MANAGER
D21 CLERK
D21 MANAGER
E01 MANAGER
E11 MANAGER
E11 OPERATOR
E21 FIELDREP
E21 MANAGER

Lenguaje SQL 9

Proyección de todos los atributos

‹ Sepuede pedir la proyección de todos los atributos de la


consulta mediante utilizando el símbolo '*'
„ La tabla resultante contendrá todos los atributos de las tablas que
aparecen en la cláusula FROM.

SELECT * FROM DEPARTMENT

DEPTNO DEPTNAME MGRNO ADMRDEPT LOCATION


A00 SPIFFY COMPUTER SERVICE DIV. 000010 A00
B01 PLANNING 000020 A00
C01 INFORMATION CENTER 000030 A00
D01 DEVELOPMENTCENTER ------ A00
D11 MANUFACTURING SYSTEMS 000060 D01
D21 ADMINISTRATION SYSTEMS 000070 D01
E01 SUPPORT SERVICES 000050 A00
E11 OPERATIONS 000090 E01
E21 SOFTWARE SUPPORT 000100 E01

Lenguaje SQL 10
Salida ordenada

‹ SQL permite controlar el orden en el que se presentan las


tuplas de una relación mediante la cláusula ORDER BY.
‹ La cláusula ORDER BY tiene la forma
ORDER BY A1 <DIRECCION>, ..., An <DIRECCION>
„ A1, ..., An son atributos de la relación resultante de la consulta
„ Ai <DIRECCION> controla si la ordenación es Ascendente 'ASC' o
descendente 'DESC' por el campo Ai. Por defecto la ordenación se
realiza de manera ascendente.
‹ La ordenación se realiza tras haber ejecutado la consulta
sobre las tuplas resultantes.
‹ La ordenación puede convertirse en una operación costosa
dependiendo del tamaño de la relación resultante.

Lenguaje SQL 11

Salida ordenada (cont.)

SELECT DEPTNO, DEPTNAME, ADMRDEPT


FROM DEPARTMENT
ORDER BY ADMRDEPT ASC

DEPTNO DEPTNAME ADMRDEPT


A00 SPIFFY COMPUTER SERVICE DIV. A00
C01 INFORMATION CENTER A00
B01 PLANNING A00
E01 SUPPORTSERVICES A00
D01 DEVELOPMENTCENTER A00
D11 MANUFACTURING SYSTEMS D01
D21 ADMINISTRATION SYSTEMS D01
E21 SOFTWARE SUPPORT E01
E11 OPERATIONS E01

Lenguaje SQL 12
Salida ordenada (cont.)

SELECT DEPTNO, DEPTNAME, ADMRDEPT


FROM DEPARTMENT
ORDER BY ADMRDEPT ASC, DEPTNO DESC

ADMRDEPT DEPTNAME DEPTNO


A00 SUPPORT SERVICES E01
A00 DEVELOPMENT CENTER D01
A00 INFORMATION CENTER C01
A00 PLANNING B01
A00 SPIFFY COMPUTER SERVICE DIV. A00
D01 ADMINISTRATION SYSTEMS D21
D01 MANUFACTURING SYSTEMS D11
E01 SOFTWARE SUPPORT E21
E01 OPERATIONS E11

Lenguaje SQL 13

Salida ordenada (cont.)

‹ En Oracle, IBM DB2 y MS-SQL Server entre otros es


posible indicar la columna de ordenación mediante un entero
„ El entero hace referencia a la posición de la columna en la relación
resultante de la consulta
SELECT LASTNAME, FIRSTNME, WORKDEPT, JOB, SEX
FROM EMPLOYEE
ORDER BY WORKDEPT DESC, JOB, LASTNAME, SEX DESC

ORDER BY WORKDEPT DESC, JOB ASC, LASTNAME ASC, SEX DESC


ORDER BY 3 DESC, 4, 1, 5 DESC
ORDER BY 3 DESC, 4 ASC, 1 ASC, 5 DESC
ORDER BY 3 DESC, JOB, LASTNAME, 5 DESC
ORDER BY WORKDEPT DESC, 4 ASC, 1 ASC, SEX DESC

Lenguaje SQL 14
Selección de filas
‹ La cláusula WHERE permite filtrar las filas de la relación resultante.
„ La condición de filtrado se especifica como un predicado.
‹ El predicado de la cláusula WHERE puede ser simple o complejo
„ Se utilizan los conectores lógicos AND, OR y NOT en lugar de los símbolos
matemáticos ∧, ∨, ¬.
‹ Las expresiones pueden contener
„ Predicados de comparación
„ BETWEEN / NOT BETWEEN
„ IN / NOT IN (con y sin subconsultas)
„ LIKE / NOT LIKE
„ IS NULL / IS NOT NULL
„ ALL, SOME/ANY (subconsultas)
„ EXISTS (subconsultas)

Lenguaje SQL 15

Selección de filas (cont.)

‹ Predicados de comparación
„ Operadores: =, <> (es el ≠), <, <=, >=. >
‹ BETWEEN es el operador de comparación para intervalos de
valores o fechas.
‹ IN es el operador que permite comprobar si un valor se
encuentra en un conjunto.
„ Puede especificarse un conjunto de valores.
„ Puede utilizarse el resultado de otra consulta.

Lenguaje SQL 16
Selección de filas (cont.)

‹ LIKE es el operador de comparación de cadenas de


caracteres.
„ SQL distingue entre mayúsculas y minúsculas
„ Las cadenas de caracteres se incluyen entre comillas simples
„ SQL permite definir patrones a través de los siguientes caracteres:
z '%', que es equivalente a "cualquier subcadena de caracteres"
z '_', que es equivalente a "cualquier carácter"
‹ IS NULL es el operador de comparación de valores nulos.

Lenguaje SQL 17

Ejemplo de selección de filas

‹ ¿Qué departamentos reportan al A00?

SELECT DEPTNO, ADMRDEPT


FROM DEPARTMENT
WHERE ADMRDEPT='A00'

DEPTNO ADMRDEPT
A00 A00
B01 A00
C01 A00
D01 A00
E01 A00

Lenguaje SQL 18
Ejemplo de selección de filas

‹ Necesito el apellido y el nivel de formación de los empleados


cuyo nivel de formación es mayor o igual a 19

SELECT LASTNAME, EDLEVEL


FROM EMPLOYEE
WHERE EDLEVEL >= 19

Lenguaje SQL 19

Ejemplo de selección de filas

‹ Necesito el número de empleado, apellido y fecha de


nacimiento de aquellos que hayan nacido después del 1 de
enero de 1955 (inclusive).
SELECT EMPNO, LASTNAME, BIRTHDATE
FROM EMPLOYEE
WHERE BIRTHDATE >='1955-01-01'
ORDER BY BIRTHDATE

EMPNO LASTNAME BIRTHDATE


000160 PIANKA 1955-04-12
000100 SPENCER 1956-12-18

Lenguaje SQL 20
Múltiples condiciones - AND

‹ Necesitoel número de empleado, el trabajo y el nivel de


formación de los analistas con un nivel de educación 16

SELECT EMPNO, JOB, EDLEVEL


FROM EMPLOYEE
WHERE JOB='ANALYST' AND EDLEVEL=16

EMPNO JOB EDLEVEL


000130 ANALYST 16

Lenguaje SQL 21

Múltiples condiciones – AND/OR

‹ Obtener el número de empleado, el trabajo y el nivel de


formación de todos los analistas con un nivel 16 y de todos
los empleados de nivel 18. La salida se clasifica por trabajo y
nivel SELECT EMPNO, JOB, EDLEVEL
FROM EMPLOYEE
WHERE (JOB='ANALYST' AND EDLEVEL=16)
OR EDLEVEL=18
ORDER BY JOB, EDLEVEL

EMPNO JOB EDLEVEL


000130 ANALYST 16
000140 ANALYST 18
000220 DESIGNER 18
000020 MANAGER 18
000010 PRES 18
Lenguaje SQL 22
SELECT con BETWEEN

‹ Obtenerel número de empleado y el nivel de todos los


empleados con un nivel entre 12 y 15
SELECT EMPNO, EDLEVEL
FROM EMPLOYEE
WHERE EDLEVEL BETWEEN 12 AND 15
ORDER BY EDLEVEL

EMPNO EDLEVEL
000310 12
000290 12
000300 14
000330 14
000100 14
000230 14
000120 14
000270 15
000250 15
Lenguaje SQL 23

SELECT con IN

‹ Listar
los apellidos y nivel de formación de todos los
empleados de nivel 14, 19 o 20.
„ El resultado clasificado por nivel y apellido
SELECT LASTNAME, EDLEVEL
FROM EMPLOYEE
WHERE EDLEVEL IN (14, 19, 20)
ORDER BY EDLEVEL, LASTNAME

LASTNAME EDLEVEL
JEFFERSON 14
LEE 14
O'CONNELL 14
SMITH 14
SPENSER 14
LUCCHESI 19
KWAN 20
Lenguaje SQL 24
Selección de valores NULL

‹ Listar el número y el nombre de los departamentos sin


director asignado

SELECT DEPTNO, DEPTNAME, MGRNO


FROM DEPARTMENT
WHERE MGRNO IS NULL;

DEPTNO DEPTNAME MGRNO


D01 DEVELOPMENTCENTER ------

Lenguaje SQL 25

Búsqueda parcial - LIKE

‹ Obtener el apellido de todos los empleados cuyo apellido


empiece por G

SELECT LASTNAME
FROM EMPLOYEE
WHERE LASTNAME LIKE 'G%';

Lenguaje SQL 26
Búsqueda parcial – LIKE
Ejemplos con %

THOMPSON
SELECT LASTNAME HENDERSON
FROM EMPLOYEE ADAMSON
WHERE LASTNAME LIKE '%SON'; JEFFERSON
JOHNSON

SELECT LASTNAME THOMPSON


FROM EMPLOYEE ADAMSON
WHERE LASTNAME LIKE '%M%N%'; MARINO

Lenguaje SQL 27

Búsqueda parcial – LIKE


Ejemplos con _
‹ ¿Qué empleados tienen una C como segunda letra de su
apellido?
SELECT LASTNAME
FROM EMPLOYEE
WHERE LASTNAME LIKE '_C%';

Lenguaje SQL 28
Búsqueda parcial – NOT LIKE

‹ Necesitotodos los departamentos excepto aquellos cuyo


número empiece por 'D'
SELECT DEPTNO, DEPTNAME
FROM DEPARTMENT
WHERE DEPTNO NOT LIKE 'D%';

DEPTNO DEPTNAME
A00 SPIFFY COMPUTER SERVICE DIV.
B01 PLANNING
C01 INFORMATION CENTER
E01 SUPPORT SERVICES
E11 OPERATIONS
E21 SOFTWARE SUPPORT

Lenguaje SQL 29

Renombramiento de columnas

SELECT EMPNO, SALARY, COMM,


SALARY+COMM AS INCOME
FROM EMPLOYEE
WHERE SALARY < 20000
ORDER BY EMPNO

EMPNO SALARY COMM INCOME


000210 18270.00 1462.00 19732.00
000250 19180.00 1534.00 20714.00
000260 17250.00 1380.00 18630.00
000290 15340.00 1227.00 16567.00
000300 17750.00 1420.00 19170.00
000310 15900.00 1272.00 17172.00
000320 19950.00 1596.00 21546.00

Lenguaje SQL 30
Renombramiento de tablas

‹ Es posible obtener “copias” de una tabla situando etiquetas


junto al nombre de las tablas.
‹ Ejemplo: en el siguiente esquema de base de datos,
queremos obtener el nombre de los empleados con al menos
dos hijos.
EMP (DNI, NOM) HIJOS (DNI, NOMH)
SELECT NOM
FROM EMP, HIJOS H1, HIJOS H2
WHERE EMP.DNI = H1.DNI AND EMP.DNI = H2.DNI AND
H1.NOMH <> H2.NOMH;
‹ Realiza el producto cartesiano de las tres tablas y da como
resultado aquellas tuplas con igual DNI en las tres y con
distinto nombre en los hijos. ¿Solución a la repetición de
nombres de distintos empleados?

Lenguaje SQL 31

Renombramiento de tablas (cont.)


‹ Utilizar clausula DISTINCT (elimina filas repetidas) e
incluir la clave de la tabla:
SELECT DISTINCT EMP.NOM, EMP.DNI
FROM EMP, HIJOS H1, HIJOS H2
WHERE EMP.DNI = H1.DNI AND EMP.DNI = H2.DNI AND
H1.NOMH <> H2.NOMH;

‹ Ejemplo: en el siguiente esquema de base de datos, se piden


los apellidos de cada empleado y de su supervisor.
‹ EMP (DNI, NOM, AP, SUELDO, ND, DNISUPERV)
SELECT E.AP, S.AP
FROM EMP E, EMP S
WHERE E.DNISUPERV = S.DNI;

‹ Las etiquetas también sirven para desambiguar.

Lenguaje SQL 32
Tipos SQL y valores literales

‹ Lanorma SQL define un conjunto de tipos para las columnas


de las tablas.
„ Habitualmente cada SGBD tiene tipos propios o particularidades
para los tipos de la norma SQL.
‹ Esnecesario consultar el manual del SGBD para obtener
información acerca de los tamaños máximos de
almacenamiento.
„ En el caso de cadenas, cual es la longitud máxima de
almacenamiento.
„ En el caso de tipos numéricos, cual es el rango de valores posibles.

Lenguaje SQL 33

Tipos SQL y valores literales

Tipo Ejemplo
BIGINT 8589934592
INTEGER 186282
SMALLINT 186
NUMERIC(8,2) 999999.99 (precisión, escala)
DECIMAL(8,2) 999999.99 (precisión, escala)
REAL 6.02257E23
DOUBLE PRECISION 3.141592653589
FLOAT 6.02257E23
CHARACTER(max) 'GREECE ' (15 caracteres)
VARCHAR(n) 'hola'
DATE date 'YYYY-MM-DD'
TIME time 'hh:mm:ss.ccc'
TIMESTAMP timestamp 'YYYY-MM-DD hh:mm:ss.ccc'

Lenguaje SQL 34
Expresiones

‹ Aunque SQL no es un lenguaje de programación de


propósito general, permite definir expresiones calculadas.
‹ Estas expresiones pueden contener
„ Referencias a columnas
„ Valores literales
„ Operadores aritméticos
„ Llamadas a funciones
‹ Los operadores aritméticos son los habituales: +, -, * y /
„ Estos operadores sólo funcionan con valores numéricos.
„ Los operadores '+' y '–' habitualmente funcionan para fechas.
‹ Aunque las normas SQL definen un conjunto mínimo de
funciones, los SGBD proporcionan una gran variedad.
„ Es necesario consultar el manual del SGBD particular.

Lenguaje SQL 35

Funciones matemáticas comunes

SQL
Descripción IBM DB2 Oracle MySQL
Server
Valor absoluto ABSs ABS ABS ABS
Menor entero >= valor CEIL CEILING CEIL CEILING
Menor entero <= valor FLOOR FLOOR FLOOR FLOOR
Potencia POWER POWER POWER POWER
Redondeo a un número
ROUND ROUND ROUND ROUND
de cifras decimales
Módulo MOD. % MOD. %

Lenguaje SQL 36
Funciones de cadena

Descripción IBM DB2 SQL Server Oracle MySQL


Convierte todos los caracteres a
LOWER LOWER LOWER LOWER
minúsculas
Convierte todos los caracteres a
UPPER UPPER UPPER UPPER
mayúsculas
Elimina los blancos del final de la
RTRIM RTRIM RTRIM RTRIM
cadena
Elimina los blancos del comienzo
LTRIM LTRIM LTRIM LTRIM
de la cadena
Devuelve una subcadena SUBSTR SUBSTRING SUBSTR SUBSTRING
Concatena dos cadenas CONCAT + CONCAT CONCAT

Lenguaje SQL 37

Operaciones aritméticas

‹ Necesito obtener el salario, la comisión y los ingresos totales


de todos los empleados que tengan un salario menor de
20000€ , clasificado por número de empleado
SELECT EMPNO, SALARY, COMM,
SALARY + COMM
FROM EMPLOYEE
WHERE SALARY < 20000
ORDER BY EMPNO
EMPNO SALARY COMM
000210 18270.00 1462.00 19732.00
000250 19180.00 1534.00 20714.00
000260 17250.00 1380.00 18630.00
000290 15340.00 1227.00 16567.00
000300 17750.00 1420.00 19170.00
000310 15900.00 1272.00 17172.00
000320 19950.00 1596.00 21546.00
Lenguaje SQL 38
Operaciones aritméticas (cont.)

SELECT EMPNO, SALARY,


SALARY*1.0375
FROM EMPLOYEE
WHERE SALARY < 20000
ORDER BY EMPNO

EMPNO SALARY

000210 18270.00 18955.125000


000250 19180.00 19899.250000
000260 17250.00 17896.875000
000290 15340.00 15915.250000
000300 17750.00 18415.625000
000310 15900.00 16496.250000
000320 19950.00 20698.125000

Lenguaje SQL 39

Expresiones en predicados

SELECT EMPNO, SALARY,


(COMM/SALARY)*100
FROM EMPLOYEE
WHERE (COMM/SALARY) * 100 > 8
ORDER BY EMPNO

EMPNO COMM SALARY

000140 2274.00 28420.00 8.001400


000210 1462.00 18270.00 8.002100
000240 2301.00 28760.00 8.000600
000330 2030.00 25370.00 8.001500

Lenguaje SQL 40
Uso de funciones

SELECT EMPNO, SALARY,


TRUNC(SALARY*1.0375, 2)
FROM EMPLOYEE
WHERE SALARY < 20000
ORDER BY EMPNO

EMPNO SALARY
000210 18270.00 18955.12
000250 19180.00 19899.25
000260 17250.00 17896.87
000290 15340.00 15915.25
000300 17750.00 18415.62
000310 15900.00 16496.25
000320 19950.00 20698.12

Lenguaje SQL 41

Uso de funciones (cont.)

SELECT CONCAT(LASTNAME || ',', FIRSTNAME ) AS NAME


FROM EMPLOYEE
WHERE WORKDEPT = 'A00'
ORDER BY NAME

NAME
HAAS, CHRISTA
LUCCHESI, VINCENZO
O'CONNELL, SEAN

Lenguaje SQL 42
Operadores de conjunto

‹ SQL incluye las operaciones:


„ UNION
„ INTERSECT
„ EXCEPT (MINUS en Oracle)
‹ Por
definición los operadores de conjunto eliminan las tuplas
duplicadas.
„ Para retener duplicados se debe utilizar <Operador> ALL

Lenguaje SQL 43

UNION - Concepto

Se
R ele lecci
me ona
RE nto r
Y D s
Y ON
DO
S R
R
R

Y Y UNION Y

r Y
i ona
c
R elec ntos Y
S me OS
ele ILL
Y AR
Y AM

R
Lenguaje SQL 44
UNION

SELECT LASTNAME, EDLEVEL LASTNAME EDLEVEL


FROM EMPLOYEE NICHOLLS 18
WHERE JOB = 'ANALYST' QUINTANA 16

SELECT LASTNAME, EDLEVEL LASTNAME EDLEVEL


FROM EMPLOYEE HAAS 18
WHERE EDLEVEL = 18 LUTZ 18
NICHOLLS 18
THOMPSON 18

SELECT LASTNAME, EDLEVEL LASTNAME EDLEVEL


FROM EMPLOYEE HAAS 18
WHERE JOB = 'ANALYST' LUTZ 18
UNION NICHOLLS 18
SELECT LASTNAME, EDLEVEL QUINTANA 16
FROM EMPLOYEE THOMPSON 18
WHERE EDLEVEL = 18

Lenguaje SQL 45

UNION

‹ Cada SELECT debe tener el mismo número de columnas


‹ Las columnas correspondientes deben tener tipos de datos
compatibles
‹ UNION elimina duplicados

‹ Si se indica, el ORDER BY debe ser la última cláusula de la


sentencia

Lenguaje SQL 46
UNION

Cada entrada debe tener 2 lineas: la


primera debe incluir el número y
nombre del director y la seguna el
número y el nombre del
departamento.
SELECT MGRNO , 'Dept.:', DEPTNAME
FROM DEPARTMENT
UNION
SELECT MGRNO, 'Mgr.:', LASTNAME
FROM DEPARTMENT D, EMPLOYEE E
WHERE D.MGRNO = E.EMPNO
ORDER BY 1,2 DESC

MGRNO DEPTNAME
000010 Mgr.: HAAS
000010 Dept.: SPIFFY COMPUTER SERVICE DIV.
000020 Mgr.: THOMPSON
000020 Dept.: PLANNING
000030 Mgr.: KWAN
000030 Dept.: INFORMATION CENTER
000050 Mgr.: GEYER
000050 Dept.: SUPPORT
Lenguaje SQLSERVICES 47

UNION
SELECT EMPNO, SUBSTR(FIRSTNME, 1, 1) || '.' || MIDINT,
LASTNAME, SALARY AS INCOME, 1 AS SORT FROM EMPLOYEE
UNION
SELECT EMPNO, '', '', BONUS, 2 AS SORT FROM EMPLOYEE
UNION
SELECT EMPNO, '', '', COMM, 3 AS SORT FROM EMPYOYEE
UNION
SELECT EMPNO, '', 'SUM:', SALARY+BONUS+COMM, 4 AS SORT FROM EMPLOYEE
ORDER BY EMPNO, SORT

EMPNO LASTNAME INCOME SORT


000010 C.I HAAS 52750.00 1
000010 1000.00 2
000010 4220.00 3
000010 SUM: 57970.00 4
000020 M.L THOMPSON 41250.00 1
000020 800.00 2
000020 3300.00 3
000020
. . SUM:. 45350.00
. 4.

Lenguaje SQL 48
UNION ALL. Concepto

Se
R ele lecci
me ona
RE
nto r
Y D s
Y ON
DO
S R
R
R

Y UNION ALL Y Y
Y

r Y
i ona
c
elec ntos Y
R S me S
ele IL LO
Y MAR
Y A

R
Lenguaje SQL 49

UNION ALL. Concepto

SELECT LASTNAME, EDLEVEL LASTNAME EDLEVEL


FROM EMPLOYEE QUINTANA 16
WHERE JOB = 'ANALYST' NICHOLLS 18

SELECT LASTNAME, EDLEVEL LASTNAME EDLEVEL


FROM EMPLOYEE HAAS 18
WHERE EDLEVEL = 18 THOMPSON 18
NICHOLLS 18
LUTZ 18

SELECT LASTNAME, EDLEVEL LASTNAME EDLEVEL


FROM EMPLOYEE QUINTANA 16
WHERE JOB = 'ANALYST' NICHOLLS 18
UNION ALL HAAS 18
SELECT LASTNAME, EDLEVEL THOMPSON 18
FROM EMPLOYEE NICHOLLS 18
WHERE EDLEVEL = 18 LUTZ 18

Lenguaje SQL 50
Consultar más de una tabla

EMPLOYEE
EMPNO LASTNAME WORKDEPT. . .
000010 HAAS A00
000020 THOMPSON C01
000030 KWAN C01
000040 PULASKI D21

DEPARTMENT
DEPTNO DEPTNAME ...

A00 SPIFFY COMPUTER SERVICE DIV.


C01 INFORMATION CENTER
D01 DEVELOPMENT CENTER
D21 ADMINISTRATION SYSTEMS

Lenguaje SQL 51

Sintaxis del JOIN: formato 1

SELECT EMPNO, LASTNAME, WORKDEPT, DEPTNAME


FROM EMPLOYEE,
DEPARTMENT
WHERE WORKDEPT = DEPTNO
AND LASTNAME = 'HAAS'

EMPNO LASTNAME WORKDEPT DEPTNAME


000010 HAAS A00 SPIFFY COMPUTER SERVICE DIV.

Lenguaje SQL 52
JOIN de tres tablas
PROJECT
PROJNO PROJNAME DEPTNO ...
AD3100 ADMIN SERVICES D01
AD3110 GENERAL AD SYSTEMS D21
AD3111 PAYROLL PROGRAMMING D21
AD3112 PERSONELL PROGRAMMING D21
AD3113 ACCOUNT. PROGRAMMING D21
IF1000 QUERY SERVICES C01

DEPARTMENT
DEPTNO DEPTNAME MGRNO . . .
A00 SPIFFY COMPUTER SERVICE DIV. 000010
B01 PLANNING 000020
C01 INFORMATION CENTER 000030
D01 DEVELOPMENT CENTER ------
D11 MANUFACTURING SYSTEMS 000060
D21 ADMINISTRATION SYSTEMS 000070
E01 SUPPORT SERVICES 000050

EMPLOYEE
EMPNO FIRSTNME MIDINIT LASTNAME ...
000010 CHRISTA I HAAS
000020 MICHAEL L THOMPSON
000030 SALLY A KWAN
000050 JOHN B GEYER
000060 IRVING F STERN
000070 EVA D PULASKI
000090 EILEEN W HENDERSON
000100 THEODORE Q SPENSER

Lenguaje SQL 53

JOIN de tres tablas

SELECT PROJNO, PROJECT.DEPTNO, DEPTNAME, MGRNO, LASTNAME


FROM PROJECT,
DEPARTMENT,
EMPLOYEE
WHERE PROJECT.DEPTNO = DEPARTMENT.DEPTNO
AND DEPARTMENT.MGRNO = EMPLOYEE.EMPNO
AND DEPARTMENT.DEPTNO = 'D21'
ORDER BY PROJNO

PROJNO DEPTNO DEPTNAME MGRNO LASTNAME

AD3110 D21 ADMINISTRATION SYSTEMS 000070 PULASKI


AD3111 D21 ADMINISTRATION SYSTEMS 000070 PULASKI
AD3112 D21 ADMINISTRATION SYSTEMS 000070 PULASKI
AD3113 D21 ADMINISTRATION SYSTEMS 000070 PULASKI

Lenguaje SQL 54
Nombre de correlación (P, D, E)

SELECT PROJNO, P.DEPTNO, DEPTNAME, MGRNO, LASTNAME


FROM PROJECT P,
DEPARTMENT D,
EMPLOYEE E
WHERE P.DEPTNO = D.DEPTNO
AND D.MGRNO = E.EMPNO
AND D.DEPTNO = 'D21'
ORDER BY PROJNO

PROJNO DEPTNO DEPTNAME MGRNO LASTNAME

AD3110 D21 ADMINISTRATION SYSTEMS 000070 PULASKI


AD3111 D21 ADMINISTRATION SYSTEMS 000070 PULASKI
AD3112 D21 ADMINISTRATION SYSTEMS 000070 PULASKI
AD3113 D21 ADMINISTRATION SYSTEMS 000070 PULASKI

Lenguaje SQL 55

JOIN de una tabla consigo misma

1. Recuperar la fila de un empleado de la tabla EMPLOYEE (E)


EMPNO . . . LASTNAME WORKDEPT . . . BIRTHDATE . . .

000100 SPENSER E21 1956-12-18

000330 LEE E21 1941-07-18

2. Recuperar el nº deparatamento de DEPARTMENT (D)


DEPTNO DEPTNAME MGRNO ADMRDEPT
. . . .
. . . .
E21 SOFTWARE SUPPORT 000100 E21

3. Recuperar el director en EMPLOYEE (M)

EMPNO . . . LASTNAME WORKDEPT . . . BIRTHDATE . . .

000100 SPENSER E21 1956-12-18

000330 LEE E21 1941-07-18

Lenguaje SQL 56
JOIN de una tabla consigo misma

¿Qué empleados
son mayores que
su director? SELECT E.EMPNO, E.LASTNAME,
E.BIRTHDATE, M.BIRTHDATE, M.EMPNO
FROM EMPLOYEE E, EMPLOYEE M,
DEPARTMENT D
WHERE E.WORKDEPT = D.DEPTNO
AND D.MGRNO = M.EMPNO
AND E.BIRTHDATE < M.BIRTHDATE

EMPNO LASTNAME BIRTHDATE BIRTHDATE EMPNO


000110 LUCCHESI 1929-11-05 1933-08-14 000010
000130 QUINTANA 1925-09-15 1941-05-11 000030
000200 BROWN 1941-05-29 1945-07-07 000060
000230 JEFFERSON 1935-05-30 1953-05-26 000070
000250 SMITH 1939-11-12 1953-05-26 000070
000260 JOHNSON 1936-10-05 1953-05-26 000070
000280 SCHNEIDER 1936-03-28 1941-05-15 000090
000300 SMITH 1936-10-27 1941-05-15 000090
000310 SETRIGHT 1931-04-21 1941-05-15 000090
000320 MEHTA 1932-08-11 1956-12-18 000100
000330 LEE 1941-07-18 1956-12-18 000100
000340 GOUNOT 1926-05-17 1956-12-18 000100

Lenguaje SQL 57

Sintaxis del JOIN: formato 2

SELECT EMPNO, LASTNAME, DEPTNO, DEPTNAME


FROM EMPLOYEE
[INNER] JOIN DEPARTMENT
ON WORKDEPT = DEPTNO

EMPNO LASTNAME DEPTNO DEPTNAME


000010 HAAS A00 SPIFFY COMPUTER SERVICE DIV.
000120 O'CONNELL A00 SPIFFY COMPUTER SERVICE DIV.
000030 KWAN C01 INFORMATION CENTER
000140 NICHOLLS C01 INFORMATION CENTER
000130 QUINTANA C01 INFORMATION CENTER
RESULTADO

Lenguaje SQL 58
Otros JOIN: RIGHT [OUTER] JOIN

SELECT EMPNO, LASTNAME, DEPTNO, DEPTNAME


FROM EMPLOYEE
RIGHT OUTER JOIN DEPARTMENT
ON WORKDEPT = DEPTNO

EMPNO LASTNAME DEPTNO DEPTNAME


000010 HAAS A00 SPIFFY COMPUTER SERVICE DIV.
000120 O'CONNELL A00 SPIFFY COMPUTER SERVICE DIV.
000030 KWAN C01 INFORMATION CENTER
000130 QUINTANA C01 INFORMATION CENTER
000140 NICHOLLS C01 INFORMATION CENTER
- - D01 DEVELOPMENT CENTER
RESULTADO
Lenguaje SQL 59

Otros JOIN: LEFT [OUTER] JOIN

SELECT EMPNO, LASTNAME, DEPTNO, DEPTNAME


FROM EMPLOYEE
LEFT OUTER JOIN DEPARTMENT
ON WORKDEPT = DEPTNO

EMPNO LASTNAME DEPTNO DEPTNAME


000010 HAAS A00 SPIFFY COMPUTER SERVICE DIV.
000030 KWAN C01 INFORMATION CENTER
000120 O'CONNELL A00 SPIFFY COMPUTER SERVICE DIV.
000130 QUINTANA C01 INFORMATION CENTER
000140 NICHOLLS C01 INFORMATION CENTER
000400 WILSON - -
RESULTADO

Lenguaje SQL 60
Otros JOIN: FULL [OUTER] JOIN

SELECT EMPNO, LASTNAME, DEPTNO, DEPTNAME


FROM EMPLOYEE
FULL OUTER JOIN DEPARTMENT
ON WORKDEPT = DEPTNO

EMPNO LASTNAME DEPTNO DEPTNAME


000120 O'CONNELL A00 SPIFFY COMPUTER SERVICE DIV.
000010 HAAS A00 SPIFFY COMPUTER SERVICE DIV.
000030 KWAN C01 INFORMATION CENTER
000130 QUINTANA C01 INFORMATION CENTER
000140 NICHOLLS C01 INFORMATION CENTER
- - D01 DEVELOPMENT CENTER
000400 WILSON - -
RESULTADO
Lenguaje SQL 61

JOINs y predicados locales

SELECT EMPNO, LASTNAME, SALARY,


DEPTNO, DEPTNAME
FROM EMPLOYEE
FULL OUTER JOIN DEPARTMENT
ON WORKDEPT = DEPTNO
WHERE SALARY > 30000 AND
DEPTNAME LIKE '%CENTER%'

EMPNO LASTNAME WORKDEPT SALARY DEPTNO DEPTNAME MGRNO


000120 O'CONNELL A00 29250.00 A00 SPIFFY COMPUTER SERVICE DIV. 000010
000010 HAAS A00 52750.00 A00 SPIFFY COMPUTER SERVICE DIV. 000010
000030 KWAN C01 38250.00 C01 INFORMATION CENTER 000030
000130 QUINTANA C01 23800.00 C01 INFORMATION CENTER 000030
000140 NICHOLLS C01 28420.00 C01 INFORMATION CENTER 000030
- - - - D01 DEVELOPMENT CENTER -
000400 WILSON - 25400.00 - - -

Lenguaje SQL 62
JOINs y predicados locales

SELECT EMPNO, LASTNAME, SALARY,


DEPTNO, DEPTNAME
FROM EMPLOYEE
FULL OUTER JOIN DEPARTMENT
ON WORKDEPT = DEPTNO
EMPNO LASTNAME WORKDEPT SALARY DEPTNO DEPTNAME MGRNO
000120 O'CONNELL A00 29250.00 A00 SPIFFY COMPUTER SERVICE DIV. 000010
000010 HAAS A00 52750.00 A00 SPIFFY COMPUTER SERVICE DIV. 000010
000030 KWAN C01 38250.00 C01 INFORMATION CENTER 000030
000130 QUINTANA C01 23800.00 C01 INFORMATION CENTER 000030
000140 NICHOLLS C01 28420.00 C01 INFORMATION CENTER 000030
- - - - D01 DEVELOPMENT CENTER -
000400 WILSON - 25400.00 - - -

WHERE SALARY > 30000 AND


DEPTNAME LIKE '%CENTER%'

EMPNO LASTNAME SALARY DEPTNO DEPTNAME


000030 KWAN 38250.00 C01 INFORMATION CENTER

Lenguaje SQL 63

JOINs

‹ Resumen
„ Existen 4 tipos de reunión y 3 condiciones de reunión que se pueden
combinar
„ Tipos de reunión
z INNER JOIN, LEFT OUTER JOIN, RIGHT OUTER JOIN, FULL
OUTER JOIN
„ Condiciones de reunión
z ON <predicado>
Š Respecto al predicado
Š No elimina duplicados de atributos comunes
z NATURAL
Š Respecto a todos los atributos comunes
Š Elimina duplicados de atributos comunes
z USING (A1, …, An)
Š Respecto a los atributos comunes indicados entre paréntesis
Š Elimina duplicados de atributos comunes indicados

Lenguaje SQL 64
Funciones de columna

‹ Las funciones de columna o funciones de agregación son


funciones que toman una colección (conjunto o
multiconjunto) de valores de entrada y devuelve un solo
valor.
‹ Las funciones de columna disponibles son: AVG, MIN, MAX,
SUM, COUNT.
‹ Los datos de entrada para SUM y AVG deben ser una
colección de números, pero el resto de operadores pueden
operar sobre colecciones de datos de tipo no numérico.

Lenguaje SQL 65

Funciones de columna

‹ Por defecto las funciones se aplican a todas las tuplas


resultantes de la consulta.
‹ Podemos agrupar las tuplas resultantes para poder aplicar las
funciones de columna a grupos específicos utilizando la
cláusula GROUP BY.
‹ En la cláusula SELECT de consultas que utilizan funciones
de columna solamente pueden aparecer funciones de
columna.
„ En caso de utilizar GROUP BY, también pueden aparecer columnas
utilizadas en la agrupación.
‹ Adicionalmente se pueden aplicar condiciones sobre los
grupos utilizando la cláusula HAVING.

Lenguaje SQL 66
Funciones de columna

‹ Cálculo del total Æ SUM (expresión)


‹ Cálculo de la media Æ AVG (expresión)

‹ Obtener el valor mínimo Æ MIN (expresión)

‹ Obtener el valor máximo Æ MAX (expresión)

‹ Contar
el número de filas que satisfacen la condición de
búsqueda Æ COUNT(*)
„ Los valores NULL SI se cuentan.
el número de valores distintos en una columna Æ
‹ Contar
COUNT (DISTINCT nombre-columna)
„ Los valores NULL NO se cuenta.

Lenguaje SQL 67

Funciones de columna

SELECT SUM(SALARY) AS SUM,


AVG(SALARY) AS AVG,
MIN(SALARY ) AS MIN,
MAX(SALARY) AS MAX,
COUNT (*) AS COUNT,
COUNT (DISTINCT WORKDEPT) AS DEPT
FROM EMPLOYEE

SUM AVG MIN MAX COUNT DEPT


873715.00 27303.59375000 15340.00 52750.00 32 8

Lenguaje SQL 68
Funciones de columna en subconjuntos

Necesito el total de
salarios del área D

SELECT SUM(SALARY) AS SUM


FROM EMPLOYEE
WHERE WORKDEPT LIKE 'D%'

SUM
373020.00
Lenguaje SQL 69

GROUP BY

Necesito conocer los salarios de todos los


empleados de los departamentos A00, B01,
y C01. Además, para estos departamentos
quiero conocer su masa salarial.

SELECT WORKDEPT, SALARY SELECT WORKDEPT, SUM(SALARY) AS SUM


FROM EMPLOYEE FROM EMPLOYEE
WHERE WORKDEPT IN ('A00', 'B01', 'C01') WHERE WORKDEPT IN ('A00', 'B01', 'C01')
ORDER BY WORKDEPT GROUP BY WORKDEPT
ORDER BY WORKDEPT

WORKDEPT SALARY
A00 52750.00
A00 46500.00 WORKDEPT SUM
A00 29250.00 A00 128500.00
B01 41250.00 B01 41250.00
C01 38250.00 C01 90470.00
C01 23800.00
C01 28420.00 Lenguaje SQL 70
GROUP BY-HAVING

Ahora sólo quiero ver los departamentos


cuya masa salarial sea superior a 50000

SELECT WORKDEPT, SUM(SALARY) AS SUM SELECT WORKDEPT, SUM(SALARY) AS SUM


FROM EMPLOYEE FROM EMPLOYEE
WHERE WORKDEPT IN ('A00', 'B01', 'C01') WHERE WORKDEPT IN ('A00', 'B01', 'C01')
GROUP BY WORKDEPT GROUP BY WORKDEPT
ORDER BY WORKDEPT HAVING SUM(SALARY) > 50000
ORDER BY WORKDEPT

W ORKDEPT SUM
W ORKDEPT SUM
A00 128500.00
B01 41250.00 A00 128500.00
C01 90470.00 C01 90470.00

Lenguaje SQL 71

GROUP BY-HAVING

Necesito, agrupado por departmento, los


trabajadores que no sean managers,
designer, y fieldrep, con una media de
salario mayor que 25000€.

SELECT WORKDEPT, JOB,AVG(SALARY) AS AVG


FROM EMPLOYEE
WHERE JOB NOT IN ('MANAGER', 'DESIGNER', 'FIELDREP')
GROUP BY WORKDEPT, JOB
HAVING AVG(SALARY) > 25000
ORDER BY WORKDEPT, JOB

WORKDEPT JOB AVG


A00 CLERK 29250.00000000
A00 PRES 52750.00000000
A00 SALESREP 46500.00000000
C01 ANALYST 26110.00000000

Lenguaje SQL 72
GROUP BY-HAVING

• Mostrar los departamentos con más de un empleado

SELECT 1 SELECT 2

SELECT WORKDEPT, COUNT(* ) AS NUMB SELECT WORKDEPT, COUNT(* ) AS NUMB


FROM EMPLOYEE FROM EMPLOYEE
GROUP BY WORKDEPT GROUP BY WORKDEPT
ORDER BY NUMB, WORKDEPT HAVING COUNT(*) > 1
ORDER BY NUMB, WORKDEPT

WORKDEPT NUMB
B01 1 WORKDEPT NUMB
E01 1
A00 3 A00 3
C01 3 C01 3
E21 4 E21 4
E11 5 E11 5
D21 6 D21 6
D11 9 D11 9

Lenguaje SQL 73

GROUP BY-HAVING

SELECT 1 WORKDEPT ED YEARS


SELECT WORKDEPT, AVG(EDLEVEL) AS ED, E11 14 27
AVG(YEAR(CURRENT_DATE-HIREDATE)) E21 15 31
AS YEARS D21 15 22
FROM EMPLOYEE E01 16 49
GROUP BY WORKDEPT D11 16 24
ORDER BY 2 A00 17 35
B01 18 24
C01 18 23
SELECT 2
SELECT WORKDEPT, AVG(EDLEVEL) AS ED,
AVG(YEAR(CURRENT_DATE-HIREDATE)) WORKDEPT ED YEARS
AS YEARS E21 15 31
FROM EMPLOYEE E01 16 49
GROUP BY WORKDEPT A00 17 35
HAVING AVG(YEAR(CURRENT_DATE-HIREDATE)) > = 30
ORDER BY 2

Lenguaje SQL 74
GROUP BY-HAVING

SELECT 1 WORKDEPT ED MIN


SELECT WORKDEPT, AVG(EDLEVEL) AS ED, A00 17 600.00
MIN(BONUS) AS MIN B01 18 800.00
FROM EMPLOYEE C01 18 500.00
GROUP BY WORKDEPT D11 16 400.00
D21 15 300.00
E01 16 800.00
E11 14 300.00

SELECT 2
SELECT WORKDEPT, AVG(EDLEVEL) AS ED,
MIN(BONUS) AS MIN WORKDEPT ED MIN
FROM EMPLOYEE E11 14 300.00
GROUP BY WORKDEPT D21 15 300.00
HAVING MIN(BONUS) = 300
ORDER BY 2

Lenguaje SQL 75

Ejecución de consultas SELECT

‹ El orden de ejecución de una consulta es el siguiente:


1. Se aplica el predicado WHERE a las tuplas del producto
cartesiano/join/vista que hay en el FROM.
2. Las tuplas que satisfacen el predicado de WHERE son
colocadas en grupos siguiendo el patrón GROUP BY.
3. Se ejecutan la cláusula HAVING para cada grupo de tuplas
anterior.
4. Los grupos obtenidos tras aplicar HAVING son los que
serán procesados por SELECT, que calculará, en los casos
que se incluyan, las funciones de agregación que le
acompañan.
5. A las tuplas resultantes de los pasos anteriores se le aplica
la ordenación descrita en la cláusula ORDER BY.

Lenguaje SQL 76
Expresión condicional CASE
‹ SQL tiene una sentencia CASE similar a la instrucción CASE
de los lenguajes de programación.
‹ La sintaxis general de esta expresión es:
CASE CASE A
WHEN C1 THEN result1 WHEN V1 THEN result1
WHEN C2 THEN result2 WHEN V2 THEN result2
... ...
WHEN Cn THEN resultn WHEN Vn THEN resultn
ELSE resultx ELSE resultx
END END
„ Ci Æ Condiciones
„ A Æ Columna
„ Vi Æ Literal
‹ Laexpresión CASE puede aparecer tanto en la cláusula
SELECT como en la cláusula WHERE.

Lenguaje SQL 77

Ejemplo de expresión condicional CASE

SELECT EMPNO, FIRSTNME, MIDINIT, LASTNAME,


CASE
WHEN EDLEVEL < 15 THEN 'SECONDARY'
WHEN EDLEVEL < 19 THEN 'COLLEGE'
ELSE 'POST GRADUATE'
END AS EDUCATION
FROM EMPLOYEE

SELECT EMPNO, FIRSTNME,


LASTNAME,
CASE SEX
WHEN 'F' THEN 'FEMALE'
WHEN 'M' THEN 'MALE' EMPNO FIRSTNME LASTNAME SEX
ELSE 'INVALID VALUE' 000260 SYBIL JOHNSON FEMALE
END AS SEX 000290 JOHN PARKER MALE
FROM EMPLOYEE 000300 PHILIP SMITH MALE
WHERE SALARY < 18000 000310 MAUDE SETRIGHT FEMALE

Lenguaje SQL 78
Casos especiales de CASE
‹ Existen dos casos especiales de uso de la expresión CASE para los que
existe una expresión propia.
„ NULLIF( exp, valor) Æ Devuelve NULL si al evaluar exp es igual a
valor.
CASE
WHEN exp = valor THEN NULL
ELSE exp
END
„ COALESCE(valor1, …, valorn ) Æ Devuelve el primer valori que
no sea NULL. Si no existe se devuelve NULL.
CASE
WHEN valor1 IS NOT NULL THEN valor1
WHEN valor2 IS NOT NULL THEN valor2

WHEN valorn IS NOT NULL THEN valorn


ELSE NULL
END

Lenguaje SQL 79

Obtener resultados con varias consultas

‹ ¿Qué salarios son mayores que el salario medio?


1ra CONSULTA Æ SELECT AVG(SALARY)
FROM EMPLOYEE 27303

2a CONSULTA Æ SELECT EMPNO, LASTNAME


FROM EMPLOYEE
WHERE SALARY > 27303

SELECT EMPNO, LASTNAME


FROM EMPLOYEE
WHERE SALARY > (SELECT AVG(SALARY) FROM EMPLOYEE)

Lenguaje SQL 80
Ejemplo de subconsulta

‹ ¿Quién tiene el menor BONUS?


SELECT EMPNO, LASTNAME, BONUS
FROM EMPLOYEE
WHERE BONUS = (SELECT MIN(BONUS) FROM EMPLOYEE)

EMPNO LASTNAME BONUS


000290 PARKER 300

Lenguaje SQL 81

Subconsultas

‹ Una subconsulta es una instrucción SELECT-FROM-WHERE


que está anidada dentro de otra consulta.
‹ Una subconsulta puede aparecer en
„ SELECT Æ La subconsulta se utilizará como valor de la columna de
la tabla resultante. La subconsulta debe devolver un único valor.
„ FROM Æ La subconsulta se utilizará como una tabla. Es necesario
que le demos nombre a esta tabla utilizando la clásula AS.
„ WHERE Æ La subconsulta es utilizada dentro de los predicados para
realizar comparaciones.
z Las subconsultas pueden devolver uno o varios valores.
z Dependiendo del número de valores se utilizarán unos operadores u
otros.

Lenguaje SQL 82
Subconsultas

SELECT lista_seleccion
FROM tabla
WHERE expr operador
(SELECT lista_seleccion
FROM tabla);

‹ La subconsulta se ejecuta una vez antes de ejecutarse la


consulta principal.
‹ Los resultados de la subconsulta son utilizados en la consulta
principal.

Lenguaje SQL 83

Subconsultas (cont.)

‹ Si estamos seguros de que la subconsulta devuelve un único


valor, es posible utilizar los operadores de comparación
habituales =, <>, <=, <, >=, >.
‹ Para subconsultas que devuelven múltiples valores se pueden
utilizar los operadores
„ IN / NOT IN
„ Los operadores de comparación habituales junto a los
cuantificadores ANY/SOME y ALL.

Lenguaje SQL 84
Subconsulta con IN

Tabla DEPARTMENT
¿Qué departamentos no DEPTNO DEPTNAME
tienen proyectos
asignados? A00 SPIFFY COMPUTER SERVICE
B01 PLANNING
C01 INFORMATION CENTER
... ...

SELECT DEPTNO, DEPTNAME


FROM DEPARTMENT
WHERE DEPTNO NOT IN (SELECT DEPTNO
FROM PROJECT)

Resultado subconsulta
Resultado final
B01
DEPTNO DEPTNAME C01
A00 SPIFFY COMPUTER SERVICE D01
D11
D21
E01
E11
Lenguaje SQL E21 85

Subconsulta con ALL

¿Qué empleados tienen


un salario mayor que la
media de salarios de
todos los
departamentos?

SELECT LASTNAME, SALARY


FROM EMPLOYEE
WHERE SALARY > ALL (SELECT AVG(SALARY)
FROM EMPLOYEE
GROUP BY WORKDEPT)

Resultado subconsulta
42833.33333333
41250.00000000
30156.66666666
Resultado final 24677.77777777
LASTNAME SALARY 25153.33333333
40175.00000000
HAAS 52750.00 20998.00000000
LUCCHESI 46500.00 Lenguaje SQL 23827.50000000 86
Subconsulta utilizando ANY o SOME

¿Qué empleados del


departamento E11
tienen el salario mayor que la
media de salarios de al menos un
departamento?

SELECT LASTNAME, SALARY, WORKDEPT


FROM EMPLOYEE
WHERE WORKDEPT = 'E11'
AND SALARY > ANY (SELECT AVG(SALARY)
FROM EMPLOYEE
GROUP BY WORKDEPT)
ORDER BY LASTNAME
Resultado subconsulta
42833.33333333
41250.00000000
30156.66666666
Resultado Final 24677.77777777
25153.33333333
LASTNAME SALARY WORKDEPT 40175.00000000
HENDERSON 29750.00 E11 20998.00000000
SCHNEIDER 26250.00 E11 23827.50000000
Lenguaje SQL 87

Subconsulta en la cláusula HAVING

Necesito un listado de los departamentos con un


salario medio por empleado (sin director) mayor
que el salario medio por empleado de la compañia
(también sin directores). El resultado lo quiero de
forma que el departamento que tenga mayor
media sea el primero.

SELECT WORKDEPT, AVG(SALARY) AS AVG_WORKDEPT


FROM EMPLOYEE
WHERE JOB <> 'MANAGER'
GROUP BY WORKDEPT
HAVING AVG(SALARY) > (SELECT AVG(SALARY)
FROM EMPLOYEE
WHERE JOB <> 'MANAGER')
ORDER BY AVG_WORKDEPT DESC

Resultado final
WORKDEPT AVG_WORKDEPT Resultado subconsulta
A00 42833.33333333 25188.80000000
C01 26110.00000000
Lenguaje SQL 88
Subconsultas correlacionadas

‹ En una subconsulta correlacionada se utilizan las tablas de la


consulta principal.
‹ El orden de ejecución de la consulta cambia.
„ Primero se busca la tabla y filas especificadas por la consulta
principal.
„ Posteriormente se ejecuta la subconsulta en la fila de la subconsulta
que está correlacionada con la consulta principal.
‹ Podemos asemejarlo al anidamiento de bucles donde el
índice del bucle externo es utilizado en el bucle interno.

Lenguaje SQL 89

Subconsultas correlacionadas

EMPNO LASTNAME WORKDEPT SALARY


000010 HAAS A00 52750.00 ¿Qué empleado tiene el
salario mayor que la media de
000030 KWAN C01 38250.00 salarios de su departamento?
000120 O'CONNELL A00 29250.00
000130 QUINTANA C01 23800.00
000140 NICHOLLS C01 28420.00
EMPLOYEE

SELECT EMPNO, LASTNAME, SALARY


FROM EMPLOYEE
WHERE SALARY >
Media de salarios del dept.
correspondiente

AVG(SALARY) AVG(SALARY)
A00 41000.00000000 C01 30156.66666666

Lenguaje SQL 90
Subconsultas correlacionadas

EMPNO LASTNAME WORKDEPT SALARY


000010 HAAS A00 52750.00
¿Qué empleado tiene el
000030 KWAN C01 38250.00 salario mayor que la media de
000120 O'CONNELL A00 29250.00 salarios de su departamento?
000130 QUINTANA C01 23800.00
000140 NICHOLLS C01 28420.00
EMPLOYEE

SELECT EMPNO, LASTNAME, SALARY


FROM EMPLOYEE E
WHERE SALARY >
(SELECT AVG(SALARY)
FROM EMPLOYEE
WHERE WORKDEPT =
E . WORKDEPT)

EMPNO LASTNAME SALARY


AVG(SALARY) AVG(SALARY)
000010 HAAS 52750.00
A00 41000.00000000 C01 30156.66666666
000030 KWAN 38250.00

Lenguaje SQL 91

Subconsultas correlacionadas con EXISTS

EMPNO LASTNAME WORKDEPT SALARY


000010 HAAS A00 52750.00
000030 KWAN C01 38250.00 ¿Qué departamentos no
000120 O'CONNELL A00 29250.00 tienen empleados?
EMPLOYEE
000130 QUINTANA C01 23800.00
000140 NICHOLLS C01 28420.00
000400 WILSON null 25400.00
DEPTNO DEPTNAME MGRNO
A00 SPIFFY COMPUTER SERVICE DIV. 000010
C01 INFORMATION CENTER 000030 DEPARTMENT
D01 DEVELOPMENT CENTER -
SELECT DEPTNO, DEPTNAME
FROM DEPARTMENT D
WHERE NOT EXISTS
(SELECT * DEPTNO DEPTNAME
FROM EMPLOYEE D01 DEVELOPMENT CENTER
WHERE
WORKDEPT = D.DEPTNO) RESULTADO

Lenguaje SQL 92
Modificación de la BBDD

‹ Lasinstrucciones SQL que permiten modificar el estado de


la BBDD son:
„ INSERT Æ Añade filas a una tabla/vista de la BBDD
„ UPDATE Æ Actualiza filas de una tabla/vista de la BBDD
„ DELETE Æ Elimina filas de una tabla/vista de la BBDD

Lenguaje SQL 93

La instrucción INSERT

‹ La inserción de tuplas se realiza con la sentencia INSERT,


„ Es posible insertar directamente valores.
„ O bien insertar el conjunto de resultados de una consulta.
„ En cualquier caso, los valores que se insertan deben pertenecer al
dominio de cada uno de los atributos de la relación.
‹ Ejemplos: CLIENTES (DNI, NOMBRE, DIR)
‹ La inserción
„ INSERT INTO CLIENTES VALUES (1111,'Mario',
'C/. Mayor, 3');
‹ Es equivalente a las siguientes sentencias
„ INSERT INTO CLIENTES (NOMBRE,DIR,DNI)
VALUES ('Mario','C/. Mayor, 3',1111);
„ INSERT INTO CLIENTES (DNI,DIR,NOMBRE)
VALUES (1111,'C/. Mayor, 3’,'Mario');

Lenguaje SQL 94
Añadir una fila
INSERT INTO TESTEMP
VALUES ('000111', 'SMITH', 'C01', '1998-06-25', 25000, NULL)

INSERT INTO TESTEMP(EMPNO, LASTNAME, WORKDEPT, HIREDATE, SALARY)


VALUES ('000111', 'SMITH', 'C01', '1998-06-25', 25000)

EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS


000111 SMITH C01 1998-06-25 25000.00 -

Lenguaje SQL 95

Añadir varias filas


‹ Ejemplo:
‹ Para la siguiente base de datos, queremos incluir en la relación GRUPOS
a todos los grupos, junto con su número de álbumes publicados:
„ GRUPOS (NOMBRE, ALBUMES) LP (TIT, GRUPO, ANIO, NUM_CANC)
‹ Solución:
INSERT INTO GRUPOS
SELECT GRUPO, COUNT (DISTINCT TIT) FROM LP
GROUP BY GRUPO;

‹ En SQL se prohíbe que la consulta que se incluye en una cláusula


INSERT haga referencia a la misma tabla en la que se quieren
insertar las tuplas.
„ En ORACLE sí está permitido

Lenguaje SQL 96
Añadir varias filas (cont.)

TESTEMP
EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS

INSERT INTO TESTEMP


SELECT EMPNO,LASTNAME,WORKDEPT,HIREDATE,SALARY,BONUS
FROM EMPLOYEE
WHERE EMPNO < = '000050'

EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS

000010 HAAS A00 1965-01-01 52750.00 1000.00


000020 THOMPSON B01 1973-10-10 41250.00 800.00
000030 KWAN C01 1975-04-05 38250.00 800.00
000050 GEYER E01 1949-08-17 40175.00 800.00
000111 SMITH C01 1998-06-25 25000.00 -----

Lenguaje SQL 97

La instrucción UPDATE

‹ La modificación de tuplas se realiza con la sentencia UPDATE,


„ Es posible elegir el conjunto de tuplas que se van a actualizar usando la
clausula WHERE.
‹ Ejemplos: CUENTAS (COD, DNI, NSUCURS, SALDO)
‹ Suma del 5% de interés a los saldos de todas las cuentas.
„ UPDATE CUENTAS SET SALDO = SALDO * 1.05;
‹ Suma del 1% de bonificación a aquellas cuentas cuyo saldo sea superior a
100.000 €.
„ UPDATE CUENTAS SET SALDO = SALDO * 1.01
WHERE SALDO > 100000;
‹ Modificación de DNI y saldo simultáneamente para el código 898.
„ UPDATE CUENTAS SET DNI='555', SALDO=10000
WHERE COD LIKE '898';

Lenguaje SQL 98
Modificar datos

Antes:
EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS
000010 HAAS A00 1965-01-01 52750.00 1000.00
000020 THOMPSON B01 1973-10-10 41250.00 800.00
000030 KWAN C01 1975-04-05 38250.00 800.00
000050 GEYER E01 1949-08-17 40175.00 800.00
000111 SMITH C01 1998-06-25 25000.00 - - - - -

UPDATE TESTEMP
SET BONUS = 500,
SALARY = 26000
WHERE EMPNO = '000111'

Después:
EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS
000010 HAAS A00 1965-01-01 52750.00 1000.00
000020 THOMPSON B01 1973-10-10 41250.00 800.00
000030 KWAN C01 1975-04-05 38250.00 800.00
000050 GEYER E01 1949-08-17 40175.00 800.00
000111 SMITH C01 1998-06-25 26000.00 500.00

Lenguaje SQL 99

Modificar datos

Antes:
EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS
000010 HAAS A00 1965-01-01 52750.00 1000.00
000020 THOMPSON B01 1973-10-10 41250.00 800.00
000030 KWAN C01 1975-04-05 38250.00 800.00
000050 GEYER E01 1949-08-17 40175.00 800.00
000111 SMITH C01 1998-06-25 25000.00 - - - - -

UPDATE TESTEMP
SET SALARY = SALARY + 1000
WHERE WORKDEPT = 'C01'

Después:
EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS
000010 HAAS A00 1965-01-01 52750.00 1000.00
000020 THOMPSON B01 1973-10-10 41250.00 800.00
000030 KWAN C01 1975-04-05 39250.00 800.00
000050 GEYER E01 1949-08-17 40175.00 800.00
000111 SMITH C01 1998-06-25 26000.00 - - - - -
Lenguaje SQL 100
La instrucción DELETE

‹ La eliminación de tuplas se realiza con la sentencia DELETE:


„ DELETE FROM R WHERE P; -- WHERE es opcional
„ Elimina tuplas completas, no columnas. Puede incluir subconsultas.
‹ Ejemplos: para la BD de CLIENTES, CUENTAS, SUCURSALES.
‹ Eliminar todas cuentas con código entre 1000 y 1100.
„ DELETE FROM CUENTAS WHERE COD BETWEEN 1000 AND
1100;
‹ Eliminar todas las cuentas del cliente “Jose María García”.
„ DELETE FROM CUENTAS WHERE DNI IN
(SELECT DNI FROM CLIENTES
WHERE NOMBRE LIKE 'Jose María García');
‹ Eliminar todas las cuentas de sucursales situadas en "Chinchón".
„ DELETE FROM CUENTAS WHERE NSUCURS IN
(SELECT NSUC FROM SUCURSALES
WHERE CIUDAD LIKE 'Chinchón');

Lenguaje SQL 101

Borrar filas

Antes:
EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS
000010 HAAS A00 1965-01-01 52750.00 1000.00
000020 THOMPSON B01 1973-10-10 41250.00 800.00
000030 KWAN C01 1975-04-05 38250.00 800.00
000050 GEYER E01 1949-08-17 40175.00 800.00
000111 SMITH C01 1998-06-25 25000.00 - - - - -

DELETE FROM TESTEMP


WHERE EMPNO = '000111'

Después:
EMPNO LASTNAME WORKDEPT HIREDATE SALARY BONUS
000010 HAAS A00 1965-01-01 52750.00 1000.00
000020 THOMPSON B01 1973-10-10 41250.00 800.00
000030 KWAN C01 1975-04-05 38250.00 800.00
000050 GEYER E01 1949-08-17 40175.00 800.00

Lenguaje SQL 102


Creación de Tablas

‹ La creación de tablas se lleva a cabo con la sentencia


CREATE TABLE.
‹ Ejemplo: creación del siguiente esquema de BD.
CLIENTES (DNI, NOMBRE, DIR) SUCURSALES (NSUC, CIUDAD)
CUENTAS (COD, DNI, NSUCURS, SALDO)
‹ Se empieza por las tablas más independientes:

CREATE TABLE CLIENTES ( CREATE TABLE SUCURSALES (


DNI VARCHAR(9) NOT NULL, NSUC VARCHAR(4) NOT NULL,
NOMBRE VARCHAR(20), CIUDAD VARCHAR(30),
DIR VARCHAR(30), PRIMARY KEY (NSUC)
PRIMARY KEY (DNI) );
);

Lenguaje SQL 103

Creación de Tablas (cont.)


‹ El siguiente paso es crear la tabla CUENTAS, con las claves externas:
CREATE TABLE CUENTAS (
COD VARCHAR(4) NOT NULL,
DNI VARCHAR(9) NOT NULL,
NSUCURS VARCHAR(4) NOT NULL,
SALDO INT DEFAULT 0,
PRIMARY KEY (COD, DNI, NSUCURS),
FOREIGN KEY (DNI) REFERENCES CLIENTES (DNI),
FOREIGN KEY (NSUCURS) REFERENCES SUCURSALES (NSUC) );

‹ Las claves candidatas, es decir, aquellos atributos no pertenecientes a la


clave que no deben alojar valores repetidos, se pueden indicar con la
clausula UNIQUE.
‹ Es posible crear una tabla como resultado de una consulta:
„ CREATE TABLE NUEVA_TABLA AS SELECT ...

Lenguaje SQL 104


Modificación y eliminación de tablas
‹ Modificación de tablas: sentencia ALTER TABLE.
„ Es posible añadir, modificar y eliminar campos. Ejemplos:
z Adición del campo PAIS a la tabla CLIENTES
„ ALTER TABLE CLIENTES ADD PAIS VARCHAR(10);
z Modificación del tipo del campo PAIS
„ ALTER TABLE CLIENTES MODIFY PAIS VARCHAR(20);
z Eliminación del campo PAIS de la tabla CLIENTES
„ ALTER TABLE CLIENTES DROP PAIS;
„ También es posible añadir nuevas restricciones a la tabla (claves
externas, restricciones check).

‹ Eliminación de tablas: sentencia DROP TABLE.


„ DROP TABLE CUENTAS;
-- Las tablas a las que referencia deben haber sido
eliminadas antes.

Lenguaje SQL 105

Vistas
‹ Una vista es una "tabla virtual".
„ La diferencia principal con respecto a las tablas normales es que
habitualmente no ocupan espacio en disco.
‹ Las vistas pueden ser utilizadas en las consultas como otra tabla más.
‹ Habitualmente las vistas son creadas para combinar información de
múltiples tablas.
„ Integración de diferentes BBDD.
‹ También es habitual su uso por razones de seguridad.
„ Podemos filtrar las columnas y/o filas a las que un usuario tiene acceso.
‹ Su sintaxis es:
‹ CREATE VIEW nombre [(col1,...)]
AS instruccion_select
[WITH CHECK OPTION]

Lenguaje SQL 106


Vistas
Tabla EMPLOYEE
EMPNO LASTNAME WORKDEPT SALARY
000010 HAAS A00 52750.00 Tabla DEPARTMENT
000030 KWAN C01 38250.00 DEPTNO DEPTNAME MGRNO
000120 O'CONNELL A00 29250.00 A00 SPIFFY COMPUTER SERVICE DIV. 000010
000130 QUINTANA C01 23800.00 C01 INFORMATION CENTER 000030
000140 NICHOLLS C01 28420.00 D01 DEVELOPMENT CENTER

CREATE VIEW EMP_DEPT (NAME, DEPARTMENT)


AS SELECT LASTNAME, DEPTNAME
FROM EMPLOYEE, DEPARTMENT
WHERE WORKDEPT = DEPTNO
SELECT * FROM EMP_DEPT;
NAME DEPARTMENT
HAAS SPIFFY COMPUTER SERVICE DIV.
O'CONNELL SPIFFY COMPUTER SERVICE DIV.
Vista EMP_DEPT KWAN INFORMATION CENTER
NICHOLLS INFORMATION CENTER
QUINTANA INFORMATION CENTER

Lenguaje SQL 107

Vistas
PROJNO PROJNAME DEPTNO RESPEMP DEPTNO DEPTNAME MGRNO
AD3100 ADMIN SERVICES D01 000010 A00 SPIFFY COMPUTER SERVICE DIV. 000010
IF1000 QUERY SERVICES C01 000030 C01 INFORMATION CENTER 000030
IF2000 USER EDUCATION C01 000030 D01 DEVELOPMENT CENTER
Tabla PROJECT Tabla DEPARTMENT

PROJNAME DEPTNAME MGRNO EMPNO LASTNAME WORKDEPT SALARY


USER EDUCATION INFORMATION CENTER 000030 000010 HAAS A00 52750.00
QUERY SERVICES INFORMATION CENTER 000030 000030 KWAN C01 38250.00
ADMIN SERVICES SPIFFY COMPUTER SERVICE DIV. 000120 O'CONNELL A00 29250.00
Vista PROJ_DEPT 000130 QUINTANA C01 23800.00
000140 NICHOLLS C01 28420.00
Tabla EMPLOYEE

PROJECT DEPARTMENT MANAGER


USER EDUCATION INFORMATION CENTER KWAN
QUERY SERVICES INFORMATION CENTER KWAN Vista PROJ_DEPT_MGR
ADMIN SERVICES SPIFFY COMPUTER SERVICE DIV.

Lenguaje SQL 108


Vistas

CREATE VIEW EMP_SALARY_DEPT (NAME, SALARY, DEPARTMENT)


AS SELECT LASTNAME, SALARY, DEPTNAME
FROM EMPLOYEE INNER JOIN DEPARTMENT
ON WORKDEPT = DEPTNO
WHERE DEPTNO = 'C01'

SELECT NAME, SALARY


FROM EMP_SALARY_DEPT
WHERE SALARY > 25000

ES COMO SI ...

SELECT LASTNAME AS NAME, SALARY


FROM EMPLOYEE INNER JOIN DEPARTMENT
ON WORKDEPT = DEPTNO
WHERE DEPTNO = 'C01' AND
SALARY > 25000

Lenguaje SQL 109

Vistas
EMPNO LASTNAME WORKDEPT SALARY
000010 HAAS A00 52750.00
000030 KWAN C01 38250.00
Tabla EMPLOYEE 000120 O'CONNELL A00 29250.00
000130 QUINTANA C01 23800.00
000140 NICHOLLS C01 28420.00

CREATE VIEW DEPT_SALARIES (DEPARTMENT, TOTAL_SALARY)


AS SELECT WORKDEPT, SUM(SALARY)
FROM EMPLOYEE
GROUP BY WORKDEPT

DEPARTMENT TOTAL_SALARY
A00 82000.00
Vista DEPT_SALARIES
C01 90470.00
PASO 1

SELECT MAX(TOTAL_SALARY) AS MAXIMUM_SALARY


FROM DEPT_SALARIES

MAXIMUM_SALARY
90470.00 PASO 2

Lenguaje SQL 110


Actualización de vistas
‹ Las vistas pueden ser utilizadas en consultas.
‹ Sin embargo, también se pueden definir vistas actualizables.
„ Estas vistas tienen que cumplir ciertas restricciones en la instrucción de
selección que la define.
‹ Restricciones de la instrucción SELECT que define la vista
„ No puede contener ningún join, es decir, la vista debe estar definida sobre
una única tabla o vista (en este caso, la vista debe ser actualizable).
„ Todas las columnas obligatorias (NOT NULL) deben aparecer en la
definición de la vista.
„ La consulta no contiene operadores de conjunto como UNION, EXCEPT o
INTERSECT. La cláusula DISTINCT tampoco está permitida.
„ Ninguna expresión de agregación puede estar incluida en la cláusula
SELECT.
„ No se puede utilizar la cláusula GROUP BY.

Lenguaje SQL 111

Vistas de lectura

Tabla EMPLOYEE
EMPNO LASTNAME WORKDEPT SALARY
000010 HAAS A00 52750.00 Tabla DEPARTMENT
000030 KWAN C01 38250.00 DEPTNO DEPTNAME MGRNO
000120 O'CONNELL A00 29250.00 A00 SPIFFY COMPUTER SERVICE DIV. 000010
000130 QUINTANA C01 23800.00 C01 INFORMATION CENTER 000030
000140 NICHOLLS C01 28420.00 D01 DEVELOPMENT CENTER

NAME DEPARTMENT
HAAS SPIFFY COMPUTER SERVICE DIV.
O'CONNELL SPIFFY COMPUTER SERVICE DIV.
Vista EMP_DEPT KWAN INFORMATION CENTER
NICHOLLS INFORMATION CENTER
QUINTANA INFORMATION CENTER

UPDATE EMP_DEPT
SET DEPARTMENT = 'DEVELOPMENT CENTER'
WHERE NAME = 'KWAN'

Lenguaje SQL 112


Restricciones en las vistas

‹ SQL3 no permite definir restricciones explícitas sobre vistas.


‹ Sin embargo, la cláusula CHECK OPTION puede
considerarse como un tipo de restricción.
‹ Si se utiliza CHECK OPTION en la creación de una vista el
SGBD no permite que una instrucción de manipulación de la
BBDD genere o actualice filas que no estén incluidas en la
consulta que ha generado la tabla.

Lenguaje SQL 113

Opción check

EMPNO LASTNAME WORKDEPT SALARY


000010 HAAS A00 52750.00
000030 KWAN C01 38250.00
Tabla EMPLOYEE 000120 O'CONNELL A00 29250.00
000130 QUINTANA C01 23800.00
000140 NICHOLLS C01 28420.00

CREATE VIEW SALARIES_1 CREATE VIEW SALARIES_2


AS AS
SELECT EMPNO, LASTNAME, SALARY SELECT EMPNO, LASTNAME, SALARY
FROM EMPLOYEE FROM EMPLOYEE
WHERE SALARY < 40000 WHERE SALARY < 40000
WITH CHECK OPTION

UPDATE SALARIES_1 UPDATE SALARIES_2


SET SALARY = 42000 SET SALARY = 42000
WHERE EMPNO = '000030' WHERE EMPNO = '000030'

FUNCIONA! NO SE PUEDE!
Lenguaje SQL 114
Cláusula WITH

‹ La norma SQL 1999 introduce la cláusula WITH con dos


propósitos:
„ Factorización de subconsultas
„ Definición de consultas recursivas.
‹ Aunque WITH forma parte de la norma, el IBM DB2 es uno
de los pocos SGBD que implementa el comportamiento
recursivo de esta cláusula.
‹ ORACLE por su parte ofrece una sintaxis y comportamiento
alternativos para la recursión.
„ Cláusula CONNECT BY PRIOR.

Lenguaje SQL 115

Factorización de subconsultas
EMPNO LASTNAME WORKDEPT SALARY HIREDATE
000010 HAAS A00 52750.00 1965-01-01
000030 KWAN C01 38250.00 1975-04-05
000120 O'CONNELL A00 29250.00 1963-12-05 EMPLOYEE
000130 QUINTANA C01 23800.00 1971-07-28
000140 NICHOLLS C01 28420.00 1976-12-15

SELECT S.HIREDECADE, MIN(S.SALARY) AS MINIMUM_SALARY


FROM
( SELECT SUBSTR(CHAR(HIREDATE,ISO),1,3)
CONCAT '0 - 9' AS HIREDECADE,
SALARY
FROM EMPLOYEE
) AS S
GROUP BY S.HIREDECADE

HIREDECADE MINIMUM_SALARY
1960 - 9 29250.00
1970 - 9 23800.00

Lenguaje SQL 116


Factorización de subconsultas (cont.)

SELECT E.EMPNO, E.LASTNAME, E.HIREDECADE, E.SALARY, M.MINIMUM_SALARY


FROM
(
SELECT EMPNO, LASTNAME,SALARY,
SUBSTR(CHAR(HIREDATE,ISO),1,3) CONCAT '0 - 9'
AS HIREDECADE
FROM EMPLOYEE

) AS E
INNER JOIN
(
SELECT S.HIREDECADE, MIN(S.SALARY) AS MINIMUM_SALARY
FROM
(
SELECT SUBSTR(CHAR(HIREDATE,ISO),1,3)
CONCAT '0 - 9' AS HIREDECADE,
SALARY
FROM EMPLOYEE
) AS S
GROUP BY S.HIREDECADE

) AS M
ON E.HIREDECADE = M.HIREDECADE

Lenguaje SQL 117

Factorización de subconsultas (cont.)


WITH
E AS
(
SELECT EMPNO, LASTNAME, SALARY,
SUBSTR(CHAR(HIREDATE,ISO),1,3) CONCAT '0 - 9'
AS HIREDECADE
FROM EMPLOYEE
),
M (HIREDECATE, MINIMUM_SALARY) AS
(
SELECT HIREDECADE, MIN(SALARY)
FROM E
GROUP BY HIREDECADE
)
SELECT E.EMPNO, E.LASTNAME, E.HIREDECADE,
E.SALARY, M.MINIMUM_SALARY
FROM E INNER JOIN M
ON E.HIREDECADE = M.HIREDECADE

Lenguaje SQL 118


Consultas recursivas

‹ Una consulta recursiva es una consulta que depende sobre


si misma.
‹ Ejemplo:
„ JEFE(NOMBRE_EMPLEADO, NOMBRE_JEFE)
„ Determinar los empleados que supervisa directa o indirectamente
Lopez.
‹ La ejecución de esta consulta se llevaría a cabo de esta
manera:
1. Obtención de los empleados supervisados por Lopez
2. Obtención de los empleados supervisados por los supervisados por
Lopez.
3. Repetir el paso 2 hasta que un empleado no supervise a nadie.

Lenguaje SQL 119

Consultas recursivas (cont.)

‹A este tipo de consultas se le denomina cierre transitivo.


‹ Existen numerosas aplicaciones en las que es necesario
calcular el cierre transitivo sobre una jerarquía.
„ Destino de vuelos
„ Partes de un coche
„ Departamentos en una empresa

Lenguaje SQL 120


SQL Recursivo
WITH
RPL (PART, SUBPART, QUANTITY) AS
(
SELECT de iniciación
SELECT ROOT.PART, ROOT.SUBPART, ROOT.QUANTITY
FROM PARTLIST ROOT
WHERE ROOT.PART = '01'

UNION ALL
SELECT iterativa
SELECT CHILD.PART, CHILD.SUBPART, CHILD.QUANTITY
FROM RPL PARENT, PARTLIST CHILD
WHERE PARENT.SUBPART = CHILD.PART
)

SELECT principal
SELECT PART, SUBPART, SUM(QUANTITY) AS QUANTITY
FROM RPL
GROUP BY PART, SUBPART

Lenguaje SQL 121

SQL Recursivo. Iniciación

SELECT ROOT.PART, ROOT.SUBPART, ROOT.QUANTITY


FROM PARTLIST ROOT
WHERE ROOT.PART = '01'
PART SUBPART QUANTITY
00 01 5
00 05 3
PART SUBPART QUANTITY
01 02 2
01 03 3 01 02 2
01 04 4 01 03 3
01 06 3 01 04 4
02 05 7 01 06 3
02 06 6 RPL
03 07 6
04 08 10
04 09 11
05 10 10
05 11 10
06 12 10
06 13 10
07 12 8
07 14 8

Lenguaje SQL 122


SQL Recursivo. Iteración 1

SELECT CHILD.PART, CHILD.SUBPART, CHILD.QUANTITY


FROM RPL PARENT, PARTLIST CHILD
WHERE PARENT.SUBPART = CHILD.PART
PART SUBPART QUANTITY
00 01 5
00 05 3
PART SUBPART QUANTITY
01 02 2
01 02 2
01 03 3
01 04 4 01 03 3
01 06 3 01 04 4
02 05 7 01 06 3
02 06 6 02 05 7
03 07 6 02 06 6
04 08 10 03 07 6
04 09 11 04 08 10
05 10 10 04 09 11
05 11 10 06 12 10
06 12 10 06 13 10
06 13 10 RPL
07 12 8
07 14 8
Tabla
PARTLIST

Lenguaje SQL 123

SQL Recursivo. Iteración 2

SELECT CHILD.PART, CHILD.SUBPART, CHILD.QUANTITY


FROM RPL PARENT, PARTLIST CHILD
WHERE PARENT.SUBPART = CHILD.PART
PART SUBPART QUANTITY PART SUBPART QUANTITY
00 01 5 01 02 2
00 05 3 01 03 3
01 02 2 01 04 4
01 03 3 01 06 3
01 04 4 02 05 7
01 06 3 02 06 6
02 05 7 03 07 6
02 06 6 No hay 04 08 10
03 07 6 correspondencia 04 09 11
04 08 10 en tabla PARTLIST 06 12 10
04 09 11 06 13 10
05 10 10 05 10 10
05 11 10 05 11 10
06 12 10 06 12 10
06 13 10 06 13 10
07 12 8 07 12 8
07 14 8 07 14 8
Tabla PARTLIST RPL

Lenguaje SQL 124


SQL Recursivo. Resultado

SELECT PART, SUBPART, SUM(QUANTITY) AS QUANTITY


FROM RPL
GROUP BY PART, SUBPART
PART SUBPART QUANTITY PART SUBPART QUANTITY
01 02 2 01 02 2
01 03 3 01 03 3
01 04 4 01 04 4
01 06 3 01 06 3
02 05 7 02 05 7
02 06 6 02 06 6
03 07 6 03 07 6
04 08 10 04 08 10
04 09 11 04 09 11
06 12 10 05 10 10
06 13 10 05 11 10
05 10 10 06 12 20
05 11 10 06 13 20
06 12 10 07 12 8
06 13 10 07 14 8
07 12 8
Resultado final
07 14 8

Lenguaje SQL 125

SQL Recursivo. Control de recursión

WITH
RPL (LEVEL, PART, SUBPART, QUANTITY) AS
(
SELECT de iniciación
SELECT 0, ROOT.PART, ROOT.SUBPART, ROOT.QUANTITY
FROM PARTLIST ROOT
WHERE ROOT.PART = '01'

UNION ALL
SELECT iterativa
SELECT PARENT.LEVEL + 1, CHILD.PART,
CHILD.SUBPART,
CHILD.QUANTITY
FROM RPL PARENT, PARTLIST CHILD
WHERE PARENT.SUBPART = CHILD.PART AND
PARENT.LEVEL < 2
)

SELECT LEVEL, PART, SUBPART, SUM(QUANTITY) AS QUANTITY


FROM RPL
GROUP BY PART, SUBPART

Lenguaje SQL 126


SQL Recursivo. Control de recursión

PART SUBPART QUANTITY


00 01 5 LEVEL PART SUBPART QUANTITY
00 05 3 0 00 01 5
01 02 2 0 00 05 3
01 03 3 1 01 02 2
01 04 4 1 01 03 3
01 06 3 1 01 04 4
02 05 7 1 01 06 3
02 06 6 1 05 10 10
03 07 6 1 05 11 10
04 08 10 2 02 05 7
04 09 11 2 02 06 6
05 10 10 2 03 07 6
05 11 10 2 04 08 10
06 12 10 2 04 09 11
06 13 10 2 06 12 10
07 12 8 2 06 13 10
07 14 8 Resultado final
Tabla PARTLIST

Lenguaje SQL 127

También podría gustarte