martes, 23 de agosto de 2011

SQL 1

ALUMNO: MARCELO ALEJO CALLE

INNER JOIN  -> Combinación interna

Con esta operación se calcula el producto cruzado de todos los registros; así cada registro en la tabla A es combinado con cada registro de la tabla B; pero sólo permanecen aquellos registros en la tabla combinada que satisfacen las condiciones que se especifiquen. Este es el tipo de JOIN más utilizado por lo que es considerado el tipo de combinación predeterminado.

SQL:2003 especifica dos formas diferentes para expresar estas combinaciones. La primera, conocida como explícita usa la palabra JOIN, mientras que la segunda es implícita y usa ',' para separar las tablas a combinar en la sentencia FROM de la declaración SELECT. Entonces siempre se genera el producto cruzado del cual se seleccionan las combinaciones que cumplan lo que indica la sentencia WHERE.

Es necesario tener especial cuidado cuando se combinan columnas con valores nulos NULL ya que el valor nulo no se combina con otro valor o con otro nulo, excepto cuando se le agregan predicados tales como IS NULL o IS NOT NULL.

Como ejemplo, la siguiente consulta toma todos los registros de la tabla Empleado y encuentra todas las combinaciones en la tabla Departamento. La sentencia JOIN compara los valores en la columna IDDepartamento en ambas tablas. Cuando no existe esta correspondencia entre algunas combinaciones, éstas no se muestran; es decir que si el número de departamento de un empleado no coincide con los números de departamento de la tabla Departamento, no se mostrará el empleado con su respectivo departamento en la tabla resultante.

Las dos consultas siguientes son similares, y se realizan de manera explicita (A) e implícita (B).

A. Ejemplo de la sentencia INNER JOIN explícita:

SELECT *
FROM   empleado
       INNER JOIN cargo
          ON empleado.codCargo = cargo.codCar

B. Ejemplo de la sentencia INNER JOIN implícita:

SELECT *
FROM   empleado,cargo
WHERE  empleado.codCargo = cargo.codCar


El empleado Gaspar y el departamento de Mercadeo no son presentados en los resultados ya que ninguno de éstos tiene registros correspondientes en la otra tabla. No existe un departamento con número 36 ni existe un empleado con número de departamento 35.
A la combinación que utiliza comparaciones dentro del predicado JOIN se le llama theta-join.
C. Ejemplo de combinación tipo theta:

SELECT *
FROM   venta
       INNER JOIN detalle_venta
          ON venta.nro < detalle_venta.nrod


Las operaciones INNER JOIN puede ser clasificadas como de equivalencia, naturales, y cruzadas.

De equivalencia (equi-join)

Es una especie de theta-join que usa comparaciones de igualdad en el predicado JOIN. Cuando se usan operadores, tales como < o > no se puede clasificar en este rango.

D. Ejemplo de combinación de equivalencia:

SELECT *
FROM   empleado
       INNER JOIN cargo
          ON empleado.codCargo = cargo.codCar

La tabla resultante presenta dos columnas llamadas IDDepartamento, una proveniente de la tabla Empleado y otra de la tabla Departamento.


Cruzada (CROSS JOIN)

Presenta el producto cartesiano de todos los registros de las dos tablas.

El código SQL para realizar este producto cartesiano enuncia las tablas que serán combinadas, pero no incluye algún predicado que filtre el resultado.

F. Ejemplo de combinación cruzada explícita:

SELECT *
FROM   venta CROSS JOIN detalle_venta

G. Ejemplo de combinación cruzada implícita:

SELECT *
FROM   empresa, contacto;

Esta clase de combinaciones son usadas pocas veces, generalmente se les agregan condiciones de filtrado con la sentencia WHERE para hallar resultados específicos.

Combinación externa (OUTER JOIN)

Mediante esta operación no se requiere que cada registro en las tablas a tratar tenga un registro equivalente en la otra tabla. El registro es mantenido en la tabla combinada si no existe otro registro que le corresponda.

Este tipo de operación se subdivide dependiendo de la tabla a la cual se le admitirán los registros que no tienen correspondencia, ya sean de tabla izquierda, de tabla derecha, o combinación completa.

De tabla izquierda (LEFT OUTER JOIN o LEFT JOIN)

El resultado de esta operación siempre contiene todos los registros de la tabla de la izquierda (la primera tabla que se menciona en la consulta), aun cuando no exista un registro correspondiente en la tabla de la derecha, para uno de la izquierda.

    La sentencia LEFT OUTER JOIN retorna la pareja de todos los valores de la tabla izquierda con los valores de la tabla de la derecha correspondientes, o retorna un valor nulo NULL en caso de no correspondencia.

A diferencia del resultado presentado en los ejemplos A y B (de combinación interna) donde no se mostraba el empleado cuyo departamento no existía; en el siguiente ejemplo se presentarán los empleados con su respectivo departamento, e inclusive se presentará el empleado, cuyo departamento no existe.

H. Ejemplo de tabla izquierda para la combinación externa:

SELECT *
FROM   empleado
       LEFT OUTER JOIN cargo
          ON empleado.codCargo = cargo.codCar

 De tabla derecha (RIGHT OUTER JOIN o RIGHT JOIN)

Esta operación es inversa a la anterior; el resultado de esta operación siempre contiene todos los registros de la tabla de la derecha (la segunda tabla que se menciona en la consulta), aun cuando no exista un registro correspondiente en la tabla de la izquierda, para uno de la derecha.

    La sentencia RIGHT OUTER JOIN retorna la pareja de todos los valores de la tabla derecha con los valores de la tabla de la izquierda correspondientes, o retorna un valor nulo NULL en caso de no correspondencia.

I. Ejemplo de tabla derecha para la combinación externa:

SELECT *
FROM   empleado
       RIGHT OUTER JOIN cargo
          ON empleado.codCargo = cargo.codCar

En este caso el área de Mercadeo fue presentada en los resultados, aunque aún no hay empleados registrados en dicha área.

combinación completa (FULL OUTER JOIN)

Esta operación presenta los resultados de tabla izquierda y tabla derecha aunque no tengan correspondencia en la otra tabla. La tabla combinada contendrá, entonces, todos los registros de ambas tablas y presentará valores nulos NULLs para registros sin pareja.

J. Ejemplo de combinación externa completa:

SELECT * 
FROM   empleado
       FULL OUTER JOIN cargo
          ON empleado.codCargo = cargo.codCar



Como se puede notar, en este caso se encuentra el empleado Gaspar con valor nulo en su área correspondiente, y se muestra además el departamento de Mercadeo con valor nulo en los empleados de esa área.

Algunos sistemas de bases de datos no soportan esta funcionalidad, pero esta puede ser emulada a través de las combinaciones de tabla izquierda, tabla derecha y de la sentencia de unión union.

K. El mismo ejemplo puede expresarse así:

SELECT *
FROM   empleado
       LEFT JOINcargo
          ON empleado.codCargo = cargo.codCar
UNION
SELECT *
FROM   empleado
       RIGHT JOIN cargo
          ON empleado.codCargo = cargo.codCar
WHERE  empleado.codCargo IS NULL


Funciones de agregación
Las funciones de agregación operan sobre conjuntos de filas de una tabla con el objeto de dar un resultado en un SELECT.

Ejemplos:
Obtener cuántas asignaturas existen en la universidad:
Obtener el mayor número de alumnos matriculados en una asignatura
Obtener la media de alumnos matriculados en una asignatura:
Obtener la suma total de los alumnos de las asignaturas:

Funciones de agregación – tipos 

  • AVG([DISTINCT | ALL] n) Valor promedio de n, ignorando nulos.
  • COUNT(* | [DISTINCT | ALL] expr) Número de filas, en donde la expresión evalúa a un valor diferente de nulo. Si se coloca * cuenta todas las filas incluyendo duplicados y filas con nulos.
  • MAX([DISTINCT | ALL] expr ) Máximo valor de la expresión ignorando nulos.
  • MIN([DISTINCT | ALL] expr) Mínimo valor de la expresión ignorando nulos.
  • SUM([DISTINCT | ALL] n) Suma de valores de n ignorando nulos
·         Los tipos de datos para expr son CHAR, VARCHAR2, NUMBER y DATE.
·         Los tipos de datos para n son numéricos.

Sintaxis
      SELECT columna, ffunciion_de_agrregaciion((columna)
      FROM tabla
      [WHERE condicion]
      [ORDER BY columna];

Ejemplo:
" Obtener cuántas asignaturas existen en la universidad: "
      SELECT COUNT(*)   FROM ASIGNATURAS;

“Obtener cuantas asignaturas hay que tengan 9 créditos y sean troncales”
      SELECT COUNT(*)   FROM ASIGNATURAS       WHERE CREDITOS=9 AND CLASE=’T’;

La cláusula GROUP BY seguida de una lista de atributos permite agrupar las tuplas en grupos que tengan los mismos valores en todos los atributos de esa lista

Ejemplo:
“Obtener el número de profesores de cada área”
      SELECT COUNT(*) ,AREA   FROM PROFESORES   GROUP BY AREA;

Si queremos que aparezca con un alias de columna: nº de profesores (hay que poner doble comilla “” ya que hay espacios en blanco)
      SELECT COUNT(*) "nº de profesores",AREA
      FROM PROFESORES   GROUP BY AREA;

Si queremos que aparezca en el SELECT el literal profesores de
      SELECT COUNT(*) || ' profesores de '|| AREA
      FROM PROFESORES   GROUP BY AREA;

La cláusula HAVING permite establecer una condición sobre los grupos de manera que sólo se seleccionan aquellos grupos que la cumplen “listar los profesores y el nº de clases que imparten, pero sólo de aquellos profesores que imparten más de 10 clases”
      SELECT PROFESOR,COUNT(*)
      FROM DOCENCIA
      GROUP BY PROFESOR
      HAVING COUNT(*)>10;

No hay comentarios:

Publicar un comentario