tema ii: modelo entidad relación 2012

Anuncio
2012
UNAN – LEÓN
Departamento de Computación
Asignatura:
DISEÑO DE BASE DE DATOS
TEMA II:
MODELO ENTIDAD RELACIÓN
Características del Modelo E-R Extendido
TEMA 2(Continuación): CARACTERÍSTICAS DEL MODELO E-R EXTENDIDO
Aunque los conceptos básicos de E-R pueden modelar la mayoría de las características de las
bases de datos, algunos aspectos de una base de datos pueden ser más adecuadamente
expresados mediante ciertas extensiones del modelo E-R básico. En este apartado se discuten
las características E-R extendidas de especialización, generalización, conjuntos de entidades de
nivel más alto y más bajo, herencia de atributos y agregación.
2.11
ESPECIALIZACIÓN
Un conjunto de entidades puede incluir subgrupos de entidades que se diferencian de alguna
forma de las otras entidades del conjunto. Por ejemplo, un subconjunto de entidades en un
conjunto de entidades puede tener atributos que no son compartidos por todas las entidades del
conjunto de entidades. El modelo E-R proporciona una forma de representación de estos grupos
de entidades distintos.
Considérese el conjunto de entidades persona con atributos nombre, calle y ciudad. Una
persona puede clasificarse además como:
Cliente
Empleado
Cada uno de estos tipos de persona se describen mediante un conjunto de atributos que
incluyen los atributos del conjunto de entidades Persona más otros posibles atributos
adicionales. Por ejemplo, las entidades Cliente se pueden describir además mediante el atributo
id-cliente, mientras que las entidades empleado se pueden describir además mediante los
atributos id-empleado y sueldo. El proceso de designación de subgrupos dentro de un conjunto
de entidades se denomina especialización. La especialización de persona permite distinguir
entre las personas basándose en si son empleados o clientes.
Se puede aplicar repetidamente la especialización para refinar el esquema de diseño. Por
ejemplo, los empleados del banco se pueden clasificar en uno de los siguientes:
Oficial
Cajero
Secretaria
Cada uno de estos tipos de Empleado se describe por un conjunto de atributos que incluye
todos los atributos del conjunto de entidades empleado más otros adicionales. Por ejemplo, las
entidades Oficial se puede describir por el atributo número-despacho, las entidades Cajero por
los atributos número-sección y horas-semana, y las entidades Secretaria por el atributo horassemana. Además, las entidades Secretaria pueden participar en una relación secretaria-de, que
identifica al empleado ayudado por una secretaria.
Un conjunto de entidades se puede especializar por más de una característica distintiva. En el
ejemplo, la característica distintiva entre entidades Empleado es el trabajo que realiza el
empleado. Otra especialización coexistente podría estar basada en si la persona es un
trabajador temporal o fijo, resultado en los conjuntos de entidades empleado-temporal y
empleado-fijo. Cuando se forma más de una especialización de un conjunto de entidades, una
entidad en particular puede pertenecer a varias especializaciones. Por ejemplo, una empleada
dada puede ser una empleada temporal y secretaria. En términos de un diagrama E-R, la
especialización se representa mediante un componente triangular etiquetado ES. La etiqueta ES
representa, por ejemplo, que un cliente «es» una persona. La relación ES se puede llamar
2
Características del Modelo E-R Extendido
también relación superclase-subclase. Los conjuntos de entidades de nivel más alto y más
bajo se representan como conjuntos de entidades regulares, es decir, como rectángulos que
contienen el nombre del conjunto de entidades.
2.12
GENERALIZACIÓN
El refinamiento a partir de un conjunto de entidades inicial en sucesivos niveles de subgrupos de
entidades representa un proceso de diseño descendente en el que las distinciones se hacen
explícitas. El proceso de diseño puede ser también de una forma ascendente, en el que varios
conjuntos de entidades se sintetizan en un conjunto de entidades de nivel más alto basado en
características comunes. El diseñador de la base de datos puede haber identificado primero el
conjunto de entidades cliente con los atributos nombre, calle, ciudad e id-cliente, y el conjunto de
entidades empleado con los atributos nombre, calle, ciudad, id-empleado y sueldo. Hay
similitudes entre el conjunto de entidades Cliente y el conjunto de entidades Empleado en el
sentido de que tienen varios atributos en común. Esta similitud se puede expresar mediante la
generalización, que es una relación contenedora que existe entre el conjunto de entidades de
nivel más alto y uno o más conjuntos de entidades de nivel más bajo.
En el ejemplo, Persona es el conjunto de entidades de nivel más alto y los conjuntos de
entidades Cliente y Empleado son de nivel más bajo. Los conjuntos de entidades de nivel más
alto y nivel más bajo también se pueden llamar superclase y subclase, respectivamente. El
conjunto de entidades Persona es la superclase de las subclases Cliente y Empleado. Para
todos los propósitos prácticos, la generalización es una inversión simple de la especialización.
Se aplicarán ambos procesos en combinación en el curso del diseño del esquema E-R para una
empresa. En términos del propio diagrama E-R no se distingue entre especialización y
generalización. Los niveles nuevos de representación de entidades serán distinguidos
(especialización) o sintetizados (generalización) cuando el esquema de diseño llegue a expresar
completamente la aplicación de base de datos y los requisitos de uso de la base de datos. Las
diferencias entre los dos enfoques se pueden caracterizar mediante su punto de partida y el
objetivo global.
La especialización parte de un conjunto de entidades simple; enfatiza las diferencias entre las
entidades dentro del conjunto mediante la creación de distintos conjuntos de entidades de nivel
más bajo. Estos conjuntos de entidades de nivel más bajo pueden tener atributos, o pueden
participar en relaciones que no se aplican a todas las entidades del conjunto de entidades de
nivel más alto. Realmente, la razón de que el diseñador aplique la especialización es representar
tales características diferentes. Si Cliente y Empleado no tuvieran cada una atributos únicos que
no tengan las entidades Persona en la que participan, no habría necesidad de especializar el
conjunto de entidades Persona.
La generalización procede de observar que varios conjuntos de entidades que comparten
algunas características comunes y basada en esas similitudes, la generalización sintetiza estos
conjuntos de entidades en un solo, el conjunto de entidades de nivel más alto. La generalización
se utiliza para resaltar las similitudes entre los conjuntos de entidades de nivel más bajo y para
ocultar las diferencias; también permite economizar la representación para que los atributos
compartidos no estén repetidos.
3
Características del Modelo E-R Extendido
Diagrama E-R que ilustra la representación de la Especialización y Generalización
2.13
HERENCIA DE ATRIBUTOS
Una propiedad crucial de las entidades de nivel más alto y más bajo creadas mediante
especialización y generalización es la herencia de atributos. Los atributos de los conjuntos de
entidades de nivel más alto se dice que son heredados por los conjuntos de entidades de nivel
más bajo. Por ejemplo, Cliente y Empleado heredan los atributos de Persona. Así, Cliente se
describe mediante sus atributos nombre, calle y ciudad y adicionalmente por el atributo idcliente; Empleado se describe mediante sus atributos nombre, calle y ciudad y adicionalmente
por los atributos id-empleado y sueldo.
Un conjunto de entidades de nivel más bajo (o subclase) también hereda la participación en los
conjuntos de relaciones en los que su entidad de nivel más alto (o superclase) participa.
EJEMPLO: El siguiente esquema E/R corresponde al diseño de la BD de una Escuela Infantil
para niños en la que se quiere guardar información sobre su gestión durante un curso
académico para lo cual se debe registrar:
• De los alumnos interesa conocer el número de matrícula, nombre, apellidos, fecha de
nacimiento, nombre de la madre y el padre, dirección, teléfono, edad (la cual se obtiene a
partir de la fecha de nacimiento).
• De los profesores se debe registrar número de inss, nombre, teléfono(s), dirección(es) de
correo electrónico y su titulación.
• Los alumnos realizan actividades extra curriculares de las cuales se debe conocer el
código de la actividad (único), la fecha de inicio y fin, coste y una descripción.
• Así mismo se requiere un control de los cursos coordinados por los profesores de los
cuales se conoce el número de curso, nombre y coste de realización. De cada grupo se
guarda el número de grupo(1,2,3…), el aula y número de alumnos asignados.
• Tomar en cuenta los siguientes supuestos:
• Almacenar los profesores asignados a los grupos de alumnos de tal manera que se
distinga ente profesores principales y profesores de apoyo. Cada grupo tiene un único
profesor principal y dos profesores de apoyo que no tienen porque estar
permanentemente en el aula de clase. De un profesor principal se guarda además su día
preferente de tutoría. Un profesor principal lo es obligatoriamente de un único grupo y un
profesor de apoyo puede serlo de varios grupos. Los profesores no pueden intercambiar
el papel que desempeñan.
4
Características del Modelo E-R Extendido
•
Con el fin de conseguir la certificación de calidad, la BD debe almacenar información
sobre las tutorías personalizadas que realizan los profesores principales de los grupos
con los padres de los alumnos en cada uno de los trimestres del curso escolar. De cada
tutoría realizada sobre un alumno con el profesor principal de su grupo en un
determinado trimestre se almacenará la fecha en que se realizó, hora de inicio, duración,
resumen de la visita y si asistieron el padre, la madre o ambos. Cada trimestre se
identifica por un número (10,20,30) y un año y se caracteriza por el número de días
lectivos y días festivos que tiene. No hay límite en el número de tutorías que se pueden
realizar sobre un determinado alumno en un trimestre.
5
Características del Modelo E-R Extendido
2.14
AGREGACIÓN
Una limitante del modelo E-R es que no permite efectuar relaciones entre relaciones si no que
solamente relaciones entre entidades, veamos el siguiente ejemplo que obedece a los siguientes
predicados semánticos:
• Cada Empleado trabaja en varios proyectos
• Cada empleado usa determinada maquinaria en función del proyecto en que trabaje.
Distinguimos claramente tres conjuntos entidades fuertes: Empleado, Proyecto y Maquinaria y
dos relaciones: La relación Trabaja entre Empleado y Proyecto y una relación ternaria: Usa entre
las entidades Empleado, Proyecto y Maquinaria.
Conjuntos de Relaciones Trabaja:
Nombre
Emp1
Emp1
Emp2
Emp3
Emp3
Emp4
Emp4
Id_P
P1
P2
P3
P1
P2
P1
P3
N_Horas
4
4
8
2
6
4
4
Conjunto relación: Usa (Relación Ternaria)
Nombre
Emp1
Emp1
Emp2
Emp2
Emp3
Emp3
Emp3
Emp4
Emp4
Emp4
Emp4
Id_P
P1
P2
P3
P3
P1
P1
P2
P1
P1
P3
P3
6
Id_M
M3
M2
M1
M4
M1
M2
M4
M1
M2
M1
M4
Características del Modelo E-R Extendido
La siguiente figura muestra la problemática generada (una relación redundante) al diseñar el
respectivo diagrama E-R:
Nombre
Empleado
N_Horas
Id_P
Trabaja
Proyecto
usa
Id_M
Maquinaria
E-R sin utilizar Agregación
Como se ha podido observar en el diagrama E-R, Empleado y Proyecto se relacionan 2 veces
en forma innecesaria, una manera de corregir esta problemática es utilizando agregación que no
es más que considerar a un conjunto relación como un conjunto identidad fuerte, este es el caso
de Trabaja con lo cual el diagrama E-R quedaría de la siguiente manera :
N om bre
Em pleado
N _H oras
Id_P
T rabaja
P royec to
us a
Id_M
M aquinaria
E-R utilizando Agregación
7
Características del Modelo E-R Extendido
El uso de la agregación se indica por medio del rectángulo que contiene a la relación Trabaja y
sus respectivas entidades, indicando que la relación Trabaja es una entidad fuerte en la relación
binaria Usa. El sistema ahora cuenta con 4 conjuntos entidades y un conjunto relación. Las
tablas mostradas arriba quedan iguales con la diferencia de que el conjunto relación Trabaja es
una entidad fuerte con clave primaria Nombre + Id_P, con esta extensión de los diagramas E-R
aplicada al ejemplo anterior se ha logrado construir un diagrama sin relaciones duplicadas.
Una instancia de esta base de datos se muestra a continuación:
Proyecto
Empleado
Nombre
Juan
Pedro
María
Carlos
Teresa
Id_P
Pr_1
Pr_3
Pr_4
Pr_5
Pr_6
Trabaja
Nombre
Juan
Juan
Pedro
María
María
Carlos
Carlos
Teresa
Maquinaria
Id_M
M-1
M-2
M-3
M-4
M-5
Id_P
Pr1
Pr2
Pr1
Pr3
Pr4
Pr5
Pr1
Pr6
N_Horas
10
15
12
8
10
12
15
18
Usa
Nombre
Juan
Juan
Pedro
María
María
Carlos
Carlos
Teresa
Id_P
Pr1
Pr2
Pr1
Pr3
Pr4
Pr5
Pr1
Pr6
Id_M
M-1
M-2
M-1
M-2
M-3
M-3
M-4
M-5
Trabaja es una entidad fuerte que se relaciona con la entidad Maquinaria, originando el conjunto
relación Usa.
8
Descargar