Sie sind auf Seite 1von 10

LECCION 08 – CREAR CONSULTA RESUMEN

Unidad 8. Las Consultas de resumen (I)

Definición
En Access podemos definir un tipo de consultas cuyas filas resultantes son un resumen de las filas del
origen de la consulta , por eso las denominamos consultas de resumen, también se conocen como
consultas sumarias.

Es importante entender que las filas del resultado de una consulta de resumen tienen una naturaleza
distinta a las filas de las demás tablas resultantes de consultas, ya que corresponden a varias filas de la
tabla origen.

Para simplificar, veamos el caso de una consulta basada en una sola tabla, una fila de una consulta 'no
resumen' corresponde a una fila de la tabla origen, contiene datos que se encuentran en una sola fila del
origen, mientras que una fila de una consulta de resumen corresponde a un resumen de varias filas de
la tabla origen, esta diferencia es lo que va a originar una serie de restricciones que sufren las consultas de
resumen y que veremos a lo largo del tema. Por ejemplo este tipo de consulta no permite modificar los
datos del origen.

En el ejemplo que viene a continuación tienes un ejemplo de consulta normal en la que se visualizan las
filas de una tabla de oficinas ordenadas por región, en este caso cada fila del resultado se corresponde con
una sola fila de la tabla oficinas, mientras que la segunda consulta es una consulta resumen, cada fila del
resultado se corresponde con una o varias filas de la tabla oficinas.

Una consulta de resumen se define haciendo clic sobre el botón Totales en la pestaña de Diseño.

En cualquiera de los dos casos se añade una fila a la cuadrícula QBE, la fila Total:

Todas las columnas que incluyamos en la cuadrícula deberán tener un valor en esa fila, ese valor le
indicará a Access qué hacer con los valores contenidos en el campo escrito en la fila Campo:

1
LECCION 08 – CREAR CONSULTA RESUMEN

Los valores que podemos indicar en la fila Total: son los que aparecen al desplegar la lista asociada a la
celda como puedes ver en la imagen de la derecha:

Las funciones de agregado


Las funciones de agregado son funciones que permiten obtener un resultado basado en los valores
contenidos en una columna de una tabla, son funciones que sólo se pueden utilizar en una consulta de
resumen ya que obtienen un 'resumen' de los valores contenidos en las filas de la tabla.

Para utilizar estas funciones podemos escribirlas directamente en la fila Campo: de la cuadrícula como
veremos más adelante pero podemos utilizar una forma más cómoda que es seleccionando en la fila Total:
de la cuadrícula la opción correspondiente a la función.

A continuación describiremos esas opciones.

La opción Suma calcula la suma de los valores indicados en el campo. Los datos que se suman deben
ser de tipo numérico (entero, decimal, coma flotante o monetario...). El resultado será del mismo tipo
aunque puede tener una precisión mayor.

La opción Promedio calcula el promedio (la media aritmética) de los valores contenidos en el campo,
también se aplica a datos numéricos, y en este caso el tipo de dato del resultado puede cambiar según las
necesidades del sistema para representar el valor del resultado.

La opción DesvEst calcula la desviación estándar de los valores contenidos en la columna indicada
en el argumento. Si la consulta base (el origen) tiene menos de dos registros, el resultado es nulo.

2
LECCION 08 – CREAR CONSULTA RESUMEN

La opción Var calcula la varianza de los valores contenidos en la columna indicada en el argumento. Si
la consulta base (el origen) tiene menos de dos registros, el resultado es nulo.

Es interesante destacar que el valor nulo no equivale al valor 0, las funciones de resumen no
consideran los valores nulos mientras que consideran el valor 0 como un valor, por lo tanto en el promedio
y la desviación estándar los resultados no serán los mismos con valores 0 que con valores nulos.

Las opciones Mín y Max determinan los valores menores y mayores respectivamente de la columna.
Los valores de la columna pueden ser de tipo numérico, texto o fecha. El resultado de la función tendrá el
mismo tipo de dato que la columna. Si la columna es de tipo numérico Mín devuelve el valor menor
contenido en la columna, si la columna es de tipo texto Mín devuelve el primer valor en orden alfabético,
y si la columna es de tipo fecha, Mín devuelve la fecha más antigua y Max la fecha más posterior.

Las opciones Primero y Último se utilizan para obtener el primer y último registro del grupo sobre el
que se realizan los cálculos. El orden lo determina el orden cronológico en el que se escribieron los registros.
Ordenar los registros no tiene ningún efecto sobre estas opciones.

La opción Cuenta cuenta el número de valores que hay en la columna, los datos de la columna
pueden ser de cualquier tipo, y la función siempre devuelve un número entero. Si la columna contiene
valores nulos esos valores no se cuentan, si en la columna aparece un valor repetido, lo cuenta varias
veces.

Para que cuente en número de registros hay que utilizar la función Cuenta(*) devuelve el número de filas
por lo tanto contará también los valores nulos. En este caso tenemos que seleccionar la opción Expresión y
escribirlo así:

Unidad 8. Las Consultas de resumen (II)


Agrupar registros
Hasta ahora las consultas de resumen que hemos visto utilizan todas las filas de la tabla y producen una
única fila resultado.

La opción AgruparPor permite definir columnas de agrupación. Una consulta de resumen sin columnas
de agrupación obtiene una única fila resultado y los cálculos se realizan sobre todos los registros del origen.

Cuando se incluye una columna de agrupación Access forma grupos con todos los registros que tienen el
mismo valor en la columna de agrupación y cada grupo así formado genera una fila en el resultado de la
consulta y además todos los cálculos definidos se realizan sobre los registros de cada grupo. De esta forma
se pueden obtener subtotales.

3
LECCION 08 – CREAR CONSULTA RESUMEN

Por ejemplo queremos saber cuántos alumnos tenemos en cada población. Tenemos que indicar que
queremos contar los registros de la tabla Alumnado pero antes agrupándolos por el campo Poblacion. De
esta manera la función cuenta() la calculará sobre cada grupo de registros (los alumnos de la misma
población). La consulta quedaría así:

Los campos de tipo memo u OLE no se pueden definir como columnas de agrupación.

Se pueden agrupar las filas por varias columnas, en este caso se agrupan los registros que
contienen el mismo valor en cada una de las columnas de agrupación.

Todas las filas que tienen valor nulo en la columna de agrupación, pasan a formar un único grupo.

Incluir expresiones
La opción Expresión permite poner en la fila Campo: una expresión en vez de un nombre de columna.

Esta expresión tiene ciertas limitaciones. Sólo puede contener operandos que sean funciones de
agregado (las funciones que acabamos de ver (suma( ), Promedio( ), DesvEst( ), Mín( ), Max( )...) valores
fijos o nombres de columna que aparezcan con la opción AgruparPor.

En una expresión se pueden combinar varias funciones de agregado pero no se pueden anidar
funciones de agregado, por ejemplo en una expresión puedo poner Max(nºhoras)-Mín(nºhoras) pero no
Max(suma(nºhoras)).

4
LECCION 08 – CREAR CONSULTA RESUMEN

Incluir criterios de búsqueda


La opción Dónde permite poner un criterio de búsqueda que se aplicará a las filas del origen de la
consulta antes de realizar los cálculos. Por ejemplo queremos saber cuántos alumnos tenemos de Valencia,
para ello tenemos que contar los registros de la tabla alumnado pero seleccionando previamente los de
Valencia, esto se definiría de la siguiente forma:

También podemos incluir un criterio de búsqueda en una columna que no tenga la opción Dónde, en
este caso la condición se aplicará a las filas resultantes de la consulta.

Para la condición de selección se pueden utilizar los mismos operadores de condición que en una
consulta normal, también se pueden escribir condiciones compuestas (unidas por los operadores OR, AND,
NOT), existe una limitación, en la fila Criterios: no se podrá poner un nombre de columna si esta columna no
es una columna de agrupación.

Para practicar puedes realizar el Ejercicio paso a paso de crear consultas de resumen.

5
LECCION 08 – CREAR CONSULTA RESUMEN

Ejercicio paso a paso. Consultas resumen


Objetivo.
Practicar los pasos para crear consultas de resumen.

Ejercicio 1.
Empezaremos por crear una consulta que nos diga cuántos cursos tenemos, cuántas horas suponen,
cuál es la media horaria de los cursos y cuántas horas tiene el curso más largo.

1 Abre la base de datos Clases.accdb de la carpeta Mis ejercicios.

2 Haz clic en el botón Diseño de Consulta en la pestaña Crear.

A continuación se abrirá el cuadro Mostrar tabla. Para saber qué tablas necesitaremos tenemos que
pensar a partir de qué campo se va a calcular lo que queremos obtener, en nuestro caso todos los datos
necesarios están en la tabla Cursos.

3 Haz clic en la tabla Cursos, quedará así seleccionada.

4 Haz clic en el botón Agregar.

5 Pulsa el botón Cerrar para cerrar el cuadro de diálogo.

Ya tenemos la ventana Diseño de consulta con la tabla añadida, vamos ahora a indicar qué campos
(columnas) se van a utilizar.

6 Haz doble clic sobre el campo Codigo Curso de la tabla (lo utilizaremos para calcular cuántos cursos
hay).

7 Haz doble clic sobre el campo nºhoras (lo utilizaremos para calcular cuántas horas tenemos en total).

8 Haz doble clic otra vez sobre el campo nºhoras (lo utilizaremos para calcular cuánto es la media
horaria).

9 Haz doble clic otra vez sobre el campo nºhoras (lo utilizaremos para calcular las horas del curso más
largo).

10 Haz clic en el botón Totales de la pestaña Diseño para añadir a la rejilla la fila Total: y convertir la
consulta en una consulta de resumen.

11 En la primera columna de la rejilla (la de Código curso) cambia el valor agrupar por de la fila Total:
por el valor Cuenta. Queremos saber cuántos alumnos hay en la tabla luego tenemos que contar, además
hemos elegido el campo Codigo curso por ser la clave principal de la tabla por lo que no puede contener
valores nulos. Recuerda que la función Cuenta no cuenta los valores nulos.

12 A continuación en la misma columna, en la fila Campo:, delante de Codigo Curso escribe nº de


cursos: para que aparezca este texto como encabezado de columna.

Nota: Como en este caso queremos contar registros podemos hacerlo de otra forma, sustituye los pasos
12 y 13 por los que vienen a continuación:

6
LECCION 08 – CREAR CONSULTA RESUMEN

13 Cambiando el valor agrupar por de la fila Total: por el valor Expresión.

14 Sustituyendo el valor Codigo Curso de la fila Campo: por nº de cursos:Cuenta(*)

15 En la segunda columna de la rejilla (la primera de nºhoras) cambia el valor agrupar por de la fila
Total: por el valor Suma. Queremos saber cuántas horas tenemos en total luego tenemos que sumarlas.

16 A continuación en la misma columna, en la fila Campo:, delante de nºhoras escribe Horas totales:
para que aparezca este texto como encabezado de columna.

17 En la tercera columna de la rejilla (la segunda de nºhoras) cambia el valor agrupar por de la fila Total:
por el valor Promedio. Queremos saber cuál es la media horararia luego tenemos que utilizar la función
Promedio.

18 A continuación en la misma columna, en la fila Campo:, delante de nºhoras escribe Media horaria:
para que aparezca este texto como encabezado de columna.

19 En la cuarta y última columna de la rejilla cambia el valor agrupar por de la fila Total: por el valor Máx.
Queremos saber cuántas horas tiene el curso más largo, luego será el valor máximo que se encuentre en la
columna nºhoras.

20 A continuación en la misma columna, en la fila Campo:, delante de nºhoras escribe Horas curso mas
largo: para que aparezca este texto como encabezado de columna.

21 Haz clic en el botón Ejecutar en la pestaña de Diseño.

Observa que aparece una única fila de resultados con los totales que hemos indicado. Fíjate también en
los encabezados de las columnas, son los nombres que has escrito delante de los dos puntos : en la fila
Campo:

22 Cierra la consulta, como es la primera vez que la guardas te pedirá un nombre, pónle cursos resumen
total.

Ejercicio 2.
Vamos a crear una consulta para saber el número de alumnos matriculados en cada curso, queremos
que aparezca el código del curso, el título del curso y el número de alumnos.

Empezaremos por crear la consulta, el origen de datos será la combinación de la tabla de cursos con la de
alumnos ya que de la tabla alumnos podríamos sacar cuántos alumnos hay por código de curso pero como
queremos también el título del curso tenemos que combinar las dos tablas.

1 Haz clic en el botón Diseño de Consulta en la pestaña Crear.

A continuación se abrirá el cuadro Mostrar tabla.

2 Haz clic en la tabla Alumnado.

3 Haz clic en el botón Agregar.

4 Haz clic en la tabla Cursos.

5 Haz clic en el botón Agregar.

7
LECCION 08 – CREAR CONSULTA RESUMEN

6 Pulsa el botón Cerrar para cerrar el cuadro de diálogo.

Con esta combinación sólo saldrían los cursos que tienen alumnos, vamos a cambiar la combinación para
que también aparezcan los cursos que no tienen alumnos.

7 Haz doble clic sobre la línea que une las dos tablas y selecciona la opción Incluir TODOS los registros
de 'Cursos' y sólo aquellos registros de 'Alumnado' donde los campos combinados sean iguales. Ya
tenemos el origen de datos preparado, ahora sólo queda definir los campos a obtener.

8 Haz doble clic sobre el campo Codigo Curso de la tabla Cursos.

9 Haz doble clic sobre el campo Nombre Curso de la tabla Cursos.

10 Haz doble clic sobre el campo Codigo Alumnado de la tabla Alumnado.

11 Haz clic en el botón Totales de la pestaña de Diseño para añadir a la rejilla la fila Total: y
convertir la consulta en una consulta de resumen.

12 En la primera columna de la rejilla (la del código de curso) deja el valor agrupar por de la fila Total:.
Queremos contar cuántos alumnos hay en cada curso, la operación de contar debe afectar a todas las filas
que tengan el mismo código de curso.

13 En la segunda columna de la rejilla (la del nombre del curso) deja el valor agrupar por de la fila Total:.
Añadir este campo a los campos de agrupación no modificará los grupos que nos interesan ya que un valor
de Codigo Curso siempre está asociado el mismo valor de Nombre Curso y nos permitirá visualizarlo.

14 En la tercera columna de la rejilla (la del Código del alumno) cambia el valor agrupar por de la fila
Total: por el valor Cuenta. En este caso no podríamos haber utilizado la función cuenta(*) como en el
ejercicio anterior por los cursos que no tienen alumnos.

15 A continuación en la misma columna, en la fila Campo:, delante de Codigo Alumnado escribe nº de


alumnos: para que aparezca este texto como encabezado de columna.

16 Haz clic en el botón Ejecutar en la pestaña de Diseño.

Observa que aparece una fila por cada curso y en esa fila el total calculado

17 Cierra la consulta, como es la primera vez que la guardas te pedirá un nombre, pónle Cuantos
alumnos por curso.

Ejercicio 3.
Vamos a crear una consulta para saber el número de alumnos de Valencia matriculados en cada curso,
queremos que aparezca el título del curso y el número de alumnos. Esta consulta va a ser muy parecida a la
anterior sólo habrá que cambiar el origen de datos para que sólo cuente los alumnos de Valencia.

Empezaremos por crear la consulta.

1 Posiciónate en el Panel de Exploración.

2 Haz clic derecho sobre la consulta Cuantos alumnos por curso.

8
LECCION 08 – CREAR CONSULTA RESUMEN

3 Selecciona la opción en el menú contextual para pasar a la vista diseño.

4 Despliega el Botón de Office y selecciona la opción Guardar Como

5 Pónle a la nueva consulta el nombre Cuantos de Valencia.

6 Haz doble clic sobre el campo Poblacion de la tabla Alumnado. Necesitamos este campo para
seleccionar los alumnos.

7 En la columna de la rejilla (la de Poblacion) cambia el valor agrupar por de la fila Total: por el valor
Donde. De esta forma indicamos que la condición que se incluye en la fila Criterios: afecta a las filas del
origen de datos, se seleccionarán los registros antes de calcular nada.

8 En la fila Criterios: de esa misma columna escribe Valencia. Para formar la condición Poblacion =
'Valencia'.

9 Haz clic en el botón Ejecutar .

10 Haz clic en el botón Guardar .

11 Cierra la consulta.

Ejercicio 4.
Vamos a crear una consulta para saber el número de alumnos matriculados en cada curso, queremos
que aparezca el título del curso y el número de alumnos, pero sólo tienen que aparecer los cursos que
tengan más de 2 alumnos.

Ahora la condición de selección afecta a las filas del resultado, se basa en las filas del resultado por lo que
no utilizaremos la opción Donde.

1 Posiciónate en el Panel de Exploración.

2 Haz clic derecho sobre la consulta Cuantos alumnos por curso.

3 Selecciona la opción en el menú contextual para pasar a la vista diseño.

4 despliega el Botón de Office y selecciona la opción Guardar Como.

5 Pónle a la nueva consulta el nombre Cursos con mas de 2 alumnos.

6 En la fila Criterios: de la columna que saca el nº de alumnos escribe >2. Para formar la condición
Cuenta(Codigo Alumnado) > 2.

7 Haz clic en el botón Ejecutar .

8 Haz clic en el botón Guardar .

9 Cierra la consulta.

9
LECCION 08 – CREAR CONSULTA RESUMEN

Nota: Se puede mejorar la consulta ya que no hace falta que la combinación de las dos tablas obtenga los
cursos que no tienen alumnos (no cumplirían la condición). Solo tienes que hacer doble clic sobre la línea
que une las dos tablas y volver a dejar la primera opción en el cuadro de diálogo Propiedades de la
combinación.

10

Das könnte Ihnen auch gefallen