Practica 1 BD II - 2023
Practica 1 BD II - 2023
Practica 1 BD II - 2023
Práctica Nª 1
Escuela de Tecnología – Área Base de Datos
Base de Datos 2
Optimización de Query’s
Requisitos:
· Motor de base de datos a utilizar: POSTRESQL
· IDE: PgAdmin III: editor de consultas SQL
Y la siguiente consulta: “Listar los datos de los productos que vende la Sucursal de JUNIN”
Sabiendo que:
- CT(productos) = 7000
- CT(vendedores) = 300
- CV(sucursal= ‘JUNIN’, vendedores) = 10
- 1000 productos de vendores de JUNIN
Se pide:
a) Construir el árbol inicial de la consulta.
b) Suponiendo que solo evaluamos la cantidad de lecturas con costo constante igual a 1, hallar el plan
de ejecución que resulte del árbol con menor costo total.
2. Dado lo siguiente:
Tablas:
MATERIAS (idmateria, nombre_materia, Total_hs)
PK(idmateria) CK(nombre_materia)
TEMAS (idtema, nombre_tema)
PK(idtema) CK(nombre_tema)
MATERIAS_TEMAS (materia, tema)
PK(materia + tema) FK(materia,MATERIAS) FK(tema, TEMAS)
Sabiendo que:
- CT(materias) = 500
Práctica Nª 1
Escuela de Tecnología – Área Base de Datos
Base de Datos 2
- CT(temas) = 1000
- CT(materias_temas) = 700
- El tema ‘Interbloqueo’ está en el 5% de las materias
- No hay nombres de temas repetidos para una misma materia
- CV(total_hs > 90, materias) = 125
- 10 materias con total de horas superior a 90 que incluyen el tema Interbloqueo
Y la consulta: “Materias con total de horas superior a 90 y que incluyan el tema Interbloqueo”
SELECT nombre_materia
FROM MATERIAS_TEMAS MT,MATERIAS M, TEMA T
WHERE M.total_hs >90 AND
MT.materia = M.idmateria AND
MT.tema = T.idtema AND
T.nombre_tema= ’Interbloqueo’;
Se pide:
a) Construir el árbol inicial de la consulta.
b) Obtener el árbol optimizado pesado con la cantidad de lecturas con costo constante igual a 1. Describiendo
el costo de cada paso.
c) Reescribir el query en base al Plan de Ejecución con menor costo.
Dada la siguiente consulta para obtener: “Los pilotos que ganaron carreras en el segundo semestre del 2009”
SELECT P.nombre
FROM PILOTO P, CARRERA C, CORRIO_EN E
WHERE P.cod_piloto=E.cod_piloto AND C.id_carrera=E.id_carrera
AND C.fecha >= '01/07/2006' AND C..fecha <= '31/12/2006'
AND E.posic_carrera=1
Se pide
a) Construir el árbol inicial de la consulta.
b) Aplicar paso a paso las reglas de optimización que se puedan para construir un árbol optimizado. Justificar.
Práctica Nª 1
Escuela de Tecnología – Área Base de Datos
Base de Datos 2
Obtener el plan de ejecución del query y explicar que está haciendo en cada uno de los siguientes casos:
a) Con el query como se presenta.
b) Mejorando el árbol de ejecución inicial.
c) Creando las PK y ejecutando el resultado obtenido en el punto b.
d) Creando las FK, sin creación de índices implícita, incluyendo la mejora del punto c y
ejecutando al resultado obtenido en el punto b.
e) Crear los índices asociados a las FK y ejecutando el resultado obtenido en el punto b.
Con las claves primarias y foráneas creadas, realizar un estudio de índices para cada una de las
sentencias:
a) Crear índices para todos los atributos de la sentencia, salvo los que sean clave o figuren
únicamente en la cláusula Select.
b) Determinar el costo de ejecución de la sentencia SQL antes de crear ningún índice.
c) Determinar el costo después de la creación de cada índice, de forma individual, y en
combinación con otros índices. Pruebe con distintos tipos de índices
d) ¿Qué índices se consideran más adecuados? ¿Por qué?
e) Mostrar el explain de la optimización obtenida mediante el uso de índices.
b. SELECT *
FROM employee e, department d
WHERE d.department_id IN (5,11,19) AND
e.department_id = d.department_id
Se pide:
a) Ejecutar las consultas sin el índice.
b) Estudiar el plan de ejecución de cada query ejecutado (salida del EXPLAIN)
c) Crear los índices que se consideren necesarios y ejecutar los mismos select, comparando los distintos
planes de ejecución para las posibilidades consideradas.
d) Elegir la mejor combinación consulta-índice.
Observaciones:
El explain query del PgAdmin III le mostrará que índices se están usando. Capturar en cada caso la salida
de este explain.
El backup de la base foodmart será publicada en plataformaed.unnoba.edu.ar
Hoja 3 de 3 Área Base de Datos | Escuela de Tecnología | UNNOBA