Manual de SQL
NOTA: Este manual llegó a mis manos por medio de un amigo y no trae el nombre del autor, lo reproduzco porque creo que será de utilidad para muchos, pero aclaro que NO SOY EL AUTOR.
SQL (Structure Query Language)
LMD (Lenguaje de Manipulación de Datos)
SELECT
SELECT [DISTINCT] | *
FROM
[WHERE ]
EJ: Visualizar todos los vuelos que tengan como origen o destino Cáceres.
SELECT *
FROM VUELOS
WHERE ORIGEN='CACERES'
OR DESTINO='CACERES'
EJ: Visualizar todos los vuelos que tengan como origen Madrid o Londres y como destino Londres o Madrid.
SELECT *
FROM VUELOS
WHERE (ORIGEN='MADRID'
AND DESTINO='LONDRES')
OR (ORIGEN='LONDRES'
AND DESTINO='MADRID')
Claúsula IN
Expresa la pertenencia del valor de una columna a un determinado conjunto de valores.
EJ: Seleccionar aquellos vuelos que tengan como origen Madrid, Barcelona o Sevilla.
SELECT *
FROM VUELOS
WHERE ORIGEN IN ('MADRID','BARCELONA','SEVILLA')
ó también
SELECT *
FROM VUELOS
WHERE ORIGEN='MADRID' OR ORIGEN='BARCELONA' OR ORIGEN='SEVILLA'
EJ: Visualizar todos los vuelos existentes excepto aquellos que llegan a Londres o a Copenhague.
SELECT *
FROM VUELOS
WHERE DESTINO NOT IN ('LONDRES','COPENHAGUE')
Claúsula BETWEEN
Sirve para establecer o expresar un rango de valores. Obedece a la siguiente sintaxis:
BETWEEN valor1 AND valor2
El rango será [valor1, valor2], extremos incluidos.
EJ: Recuperar todos los vuelos que salgan entre las 6 y las 12 de la mañana.
SELECT *
FROM VUELOS
WHERE HORA_SALIDA BETWEEN '06.00.00'
AND '12.00.00'
ó también
SELECT *
FROM VUELOS
WHERE HORA_SALIDA >= '06.00.00'
AND HORA_SALIDA <= '12.00.00'
EJ: En la columna NUM_VUELO representaré los vuelos con 6 caracteres. Los dos primeros caracteres indicarán la compañía a la que pertenece cada vuelo (IB?Iberia, BA?British Airways), los cuatro caracteres siguientes corresponderán al número de vuelo. Bajo estas condiciones recupérense todos los vuelos que no pertenecen a IBERIA.
SELECT *
FROM VUELOS
WHERE NUM_VUELO NOT BETWEEN 'IB0000'
AND 'IB9999'
[pagebreak]
Claúsula LIKE
Sirve para especificar, con la ayuda de metasímbolos, cadenas de caracteres que comparten ciertos caracteres en común. Los metasímbolos que serán utilizados son:
% Equivale a una cadena de caracteres de longitud comprendida entre 0 y n.
'AB%' AB, ABCDE, AB 497
_ Equivale a un único carácter
'A_B' A B, A4B, AJB
EJ: Recuperar todos los vuelos pertenecientes a la compañía IBERIA.
SELECT *
FROM VUELOS
WHERE NUM_VUELOS LIKE 'IB%'
ó también
SELECT *
FROM VUELOS
WHERE NUM_VUELOS LIKE 'IB_ _ _ _'
[pagebreak]
Expresiones aritméticas
+, -, *, /
Pueden ser utilizadas tanto después de SELECT como después de WHERE. En el primer caso trabajarían sobre columnas y en el segundo sobre filas.
EJ: Visualizar la longitud y la envergadura de todos los aviones, expresando las magnitudes en pies (en la base de datos está almacenado en metros, para pasar 1 metro a pies se ha de multiplicar por 3.28), y la velocidad de crucero en mph(está en Km/h, habrá que dividir por 1.6).
SELECT LONGITUD*3.28, ENVERGADURA*3.28, VELO_CRUC/1.6
FROM AVIONES
┌──┐ ┌──┐ ┌──┐
Etiquetas ? └──┘ └──┘ └──┘
EJ: Relación entre la longitud y la envergadura de todos los aviones.
SELECT LONGITUD/ENVERGADURA
FROM AVIONES
EJ: Seleccionar aquellos aviones cuya longitud supere a su envergadura en más de un 10%.
SELECT *
FROM AVIONES
WHERE LONGITUD > ENVERGADURA*1.10
[pagebreak]
Funciones de columna
Son funciones que operan con todas las filas que cumplen la condición expuesta en la claúsula WHERE. Su resultado es un único valor. Sintaxis:
1?) ([DISTINCT] )
2?) (), donde es una expresión aritmética en la cual debe participar, al menos, una columna.
3?) COUNT(*)
Funciones
:
MIN: Calcula el valor mínimo de una columna.
MAX: Calcula el valor máximo de una columna.
AVG: Calcula la media aritmética de una columna.
SUM: Calcula la suma de todos los campos de una columna.
COUNT: Cuenta el n? de filas de una columna.
A
B
3
5
2
8
3
7
4
3
COUNT(A)=COUNT(B)
COUNT(A)=4, COUNT(B)=4
El COUNT de dos columnas de una misma tabla es igual. COUNT(*) sirve para obtener el n? de filas.
EJ: Seleccionar los valores mínimo y máximo de la columna que almacena las velocidades de crucero.
SELECT MIN(VELO_CRUC), MAX(VELO_CRUC)
FROM AVIONES
EJ: Averiguar a que hora parte el primer vuelo hacia Madrid.
SELECT MIN (HORA_SALIDA)
FROM VUELOS
WHERE DESTINO='MADRID'
Regla que cumplen las funciones de columna
La función de columna sólo podrá especificarse detrás de la particula SELECT o en la claúsula HAVING, pero nunca dentro de la claúsula WHERE.
EJ: Se desea saber cuál es el vuelo que tiene la mínima hora de salida.
SELECT *
FROM VUELOS
WHERE HORA_SALIDA=(SELECT MIN(HORA_SALIDA)
FROM VUELOS)
[pagebreak]
Claúsula GROUP BY-HAVING
Sirve para dividir una tabla en grupos de filas que comparten características comunes. La sintaxis es:
SELECT ,
FROM
[WHERE ]
[GROUP BY ]
[HAVING ]
EJ: Efectúese una SELECT que visualice el mínimo valor de hora de salida para cada uno de los diferentes destinos.
SELECT DISTINCT DESTINO
FROM VUELOS
SELECT MIN(HORA_SALIDA)
FROM VUELOS
WHERE DESTINO LIKE '%'
A continuación se muestra un ejemplo de lo que no se debe hacer:
SELECT MIN(HORA_SALIDA)
FROM VUELOS
WHERE DESTINO IN (SELECT DISTINCT DESTINO
FROM VUELOS)
Sentencia GROUP BY:
SELECT DESTINO, MIN(HORA_SALIDA)
FROM VUELOS
GROUP BY DESTINO
Tabla VUELOS ? Tabla auxiliar ? Tabla x 'MADRID'
Tabla z 'SEVILLA'
GROUP BY crea una serie de subtablas compuestas por filas con el mismo valor para la columna de agrupamiento (en este ejemplo la columna DESTINO). Se aplicarán a continuación funciones de columna sobre cada subtabla de forma independiente.
MADRID, x
BARCELONA, y
SEVILLA, z
No se puede poner en GROUP BY un campo que no se haya incluido en la sentencia SELECT.
EJ: Obtener el número de vuelos que existen para cada uno de los orígenes.
SELECT ORIGEN, COUNT(*)
FROM VUELOS
GROUP BY ORIGEN
[pagebreak]
Claúsula HAVING
Permite elegir aquellos grupos que se quieren visualizar.
EJ: Visualizar los grupos que tienen para cada uno de los orígenes la mínima hora de salida siendo anterior a las 12 horas.
SELECT ORIGEN, MIN(HORA_SALIDA)
FROM VUELOS
GROUP BY ORIGEN
HAVING MIN(HORA_SALIDA) < '12.00'
HAVING no interferirá en la agrupación por filas de GROUP BY.
EJ: Se desea seleccionar la hora de salida más temprana para cada origen y destino.
SELECT ORIGEN, DESTINO, MIN(HORA_SALIDA)
FROM VUELOS
GROUP BY ORIGEN, DESTINO
EJ: Visualizar los orígenes que tengan más de dos vuelos.
SELECT ORIGEN
FROM VUELOS
GROUP BY ORIGEN
HAVING COUNT(*) > 2
EJ: Visualizar los vuelos de IBERIA que tengan más de 150 plazas libres.
SELECT NUM_VUELO, SUM(PLAZAS_LIBRES)
FROM RESERVAS
GROUP BY NUM_VUELO
HAVING NUM_VUELO LIKE 'IB%'
AND SUM(PLAZAS_LIBRES)>150
ó también
SELECT NUM_VUELO, SUM(PLAZAS_LIBRES)
FROM RESREVAS
WHERE NUM_VUELO LIKE 'IB%'
GROUP BY NUM_VUELO
HAVING NUM_VUELO 'IB%'
AND SUM(PLAZAS_LIBRES)>150
[pagebreak]
TRATAMIENTO DE NULOS
Operaciones aritméticas
Cualquier operación aritmética sobre un campo nulo nos devolverá como resultado un valor nulo.
Tomemos como ejemplo la siguiente tabla:
NULOS
COL_A
COL_B
15
10
35
35
140
NULL
NULL
100
NULL
NULL
7
110
33
60
NULL
NULL
NULL
NULL
SELECT COL_A+COL_B
FROM NULOS
COL_A+COL_B
25
70
NULL
NULL
NULL
117
93
NULL
NULL
[pagebreak]
Funciones de columna
Ignoran los campos NULL, exceptuando la función COUNT.
SELECT AVG(COL_A)
SELECT SUM(COL_A)/COUNT(*)
AVG(COL_A)=46
SUM(COL_A)/COUNT(*)=25.5
Comparaciones
Dos valores nulos no son iguales ni son distintos, sino indeterminados.
SELECT *
FROM NULOS
WHERE COL_A=COL_B
COL_A COL_B
35 35
SELECT *
FROM NULOS
WHERE COL_A<>COL_B
COL_A COL_B
15 10
140 NULL
NULL 100
7 110
33 60
SELECT *
FROM NULOS
WHERE COL_A IS NULL
Esta orden visualiza todas las filas en las que el campo perteneciente a la columna COL_A es nulo.
[pagebreak]
Ordenación
Dependiendo del sistema gestor en uso los valores nulos serán los de mayor o los de menor peso.
NULL ? Mayor peso. en ordenación ascendente serán los últimos.
SELECT COL_A
FROM NULOS
ORDER BY COL_A
COL_A
7
15
33
35
140
NULL
NULL
NULL
NULL
DISTINCT
No elimina los valores nulos repetidos.
SELECT DISTINCT COL_A
FROM NULOS
COL_A
15
35
140
NULL
NULL
7
33
NULL
NULL
[pagebreak]
Indices únicos
Sobre una columna de índice único sólo está permitida la existencia de un valor nulo.
CREATE UNIQUE INDEX IXNULOS
ON NULOS
(COL_A)
Devolvería un error, ya que existe más de un campo con NULL.
Para este caso los nulos se interpretan como valores iguales.
GROUP BY
Todos los nulos quedarán agrupados en el mismo grupo.
SELECT COL_A, COUNT(*)
FROM NULOS
GROUP BY COL_A
COL_A COUNT(*)
15 1
35 1
140 1
NULL 4
7 1
33 1
Todos los valores NULL se agrupan y COUNT devuelve el número de filas que tenían NULL en COL_A.
[pagebreak]
SUBSELECT
Responde a la siguiente sintaxis:
SELECT
FROM
WHERE (SELECT
FROM
WHERE )
Puede ser un operador de comparación o la claúsula IN
Operadores de comparación: >,<,>=,<=,=,<>
Restricciones: ha de exigirse que el resultado de la Subselect sea un único valor al usar como concatenador un operador de comparación. Si usamos IN puede devolver más de un valor.
Cada Select se ejecuta una única vez, desde la más interna, hasta la más externa.
EJ: Se desea recuperar las plazas libres que hay en cada vuelo MADRID-LONDRES del día 20/02/92.
{Las plazas libres es un campo de la tabla de reservas. En la tabla de vuelos tenemos el origen y el destino de cada vuelo.}
SELECT *
FROM RESERVAS
WHERE FECHA_SALIDA='20.02.1992'
AND NUM_VUELO IN(SELECT NUM_VUELO
FROM VUELOS
WHERE ORIGEN='MADRID'
AND DESTINO='LONDRES')
ANY, ALL
Se usan para poder utilizar operadores de comparación con subselects que nos devuelvan más de un valor único como resultado.
SELECT
FROM
WHERE {ANY/ALL} ()
Una expresión ANY es cierta si lo es para algún valor de los que devuelve la Subselect.
Una expresión ALL es cierta si lo es para todos los valores que devuelve la Subselect.
3>ANY(2,5,7) ? Cierto
3=ANY(2,5,7) ? Falso
3>ALL(2,5,7) ? Falso
3 ALL (SELECT ENVERGADURA
FROM AVIONES)
ó también
SELECT *
FROM AVIONES
WHERE LONGITUD > (SELECT MAX(ENVERGADURA)
FROM AVIONES)
=ANY e IN tienen la misma función.
3=ANY(2,3,5) y 3 IN (2,3,5) devuelven ambos Cierto.
Subselects correlacionadas
Son un tipo especial de subselect. La sintaxis es similar:
SELECT
FROM
WHERE (SELECT
FROM
WHERE )
En habrá una sentencia del tipo
Las formas de ejecutar una subselect ordinaria y una correlacionadas son diferentes. Las subselects correlacionadas obedecen al siguiente algoritmo:
ALGORITMO Subselect_Correlacionada
1 Seleccionar fila de tabla externa
2 Ejecutar SELECT interno
3 Evaluar la condición del WHERE externo
- Cierto: la fila seleccionada en 1 será una fila de salida
4 Si existe alguna fila más en la tabla externa ir al paso 1
EJ: Se desea recuperar las reservas cuyo número de plazas libres sea mayor que la media para ese mismo vuelo.
SELECT *
FROM RESERVAS, A
WHERE PLAZAS_LIBRES > (SELECT AVG(PLAZAS_LIBRES)
FROM RESERVAS
WHERE NUM_VUELO=A.NUM_VUELO)
RESERVAS
NUM_VUELO FECHA_SALIDA PLAZAS_LIBRES
IB740 20.02.92 5
IB740 25.02.92 15
IB740 03.03.92 10
AVG(PLAZAS_LIBRES)=10
[pagebreak]
Alias
Es un sobrenombre que se le da a una tabla y que debe ser único para toda la consulta. Se escribe dejando un blanco detrás del nombre de la tabla a la cual se va a calificar.
EJ: Se quiere recuperar los aviones que tienen menos de 1 hora y cuarto de recorrido como término medio.
VUELOS
NUM_VUELO ORIGEN DESTINO DISTANCIA
B747 MADRID LONDRES 10000
B747 MADRID PARIS 4000
AVIONES
NUM_VUELO VELO_CRUC
............ ............
v=e/t, t>e/v, 1.25>e/v, v*1.25 > AVG(DISTANCIA)
SELECT AVIONES SELECT VUELOS
SELECT *
FROM AVIONES
WHERE 1.25*VELO_CRUC > (SELECT AVG(DISTANCIA)
FROM VUELOS
WHERE NUM_VUELO=AVIONES.NUM_VUELO)
EXISTS-NOT EXISTS
Se define para comprobar la existencia o ausencia del valor devuelto por una Subselect. Una expresión con EXIST devuelve Cierto si la Subselect nos devuelve al menos un valor.
WHERE EXISTS () ? Cierto
EJ: Seleccionar toda la información de vuelos para aquellos que tengan origen Madrid y en los que queden plazas libres.
SELECT *
FROM VUELOS
WHERE ORIGEN='MADRID'
AND EXISTS (SELECT *
FROM RESERVAS
WHERE PLAZAS_LIBRES > 0
AND NUM_VUELO=VUELOS.NUM_VUELO)
EJ: Obtener los tipos de avión y capacidades para aquellos en los que queden menos de 30 plazas libres (JOIN).
[pagebreak]
ORDER BY
Se define para ordenar la salida de una consulta por los campos que se especifiquen a continuación.
Sintaxis:
SELECT
FROM
WHERE
GROUP BY
HAVING
ORDER BY
ORDER BY {,}
=|
>orden<=ASC|DESC
Ej: Obtener el número de plazas libres que quedan para cada vuelo y ordenar el resultado de más a menos plazas libres. Para igual número de plazas ordénese por número de vuelo.
SELECT NUM_VUELO, SUM(PLAZAS-LIBRES)
FROM RESERVAS
GROUP BY NUM_VUELO
ORDER BY 2 DESC, NUM_VUELO
UNION-UNION ALL
Se define para recuperar, usando una única consulta, información que se obtiene a partir de más d una consulta.
Sintaxis:
{UNION[ALL]