# Conceptos fundamentales del modelo relacional El modelo relacional se basa en el concepto matemático de relación, que se representa gráficamente mediante una tabla. Codd utilizó terminología matemática para definir el modelo relacional, en concreto la de la teoría de conjuntos y de la lógica de predicados. #### El concepto de relación La **relación** es el elemento básico del modelo relacional y está compuesta por dos partes: - **Cabecera**. Formada por un conjunto fijo de atributos. Es la parte fija de la relación. Está constituida por: - El nombre del conjunto: la tabla. - El nombre de los atributos: las columnas de la tabla. - Los dominios de los que toman valores los atributos. - **Cuerpo**. El cuerpo está formado por un conjunto de filas. El número de columnas que tiene una relación recibe el nombre de **grado** de la relación, y el número de filas recibe el nombre de **cardinalidad** de la relación. Como ejemplo, la siguiente tabla representa la relación PERSONA.
**NOMBRE** **APELLIDOS** **EDAD** **TELÉFONO**
Alfonso Gutiérrez Pérez 38 698 569 854
Lucía López García 37 666 999 888
Jorge Juan Bonilla 38 632 458 785
Ana García García 29 654 987 321
Diego Rodríguez Gracia 36 632 985 632
Marta Pérez Martínez 34 678 521 456
Alberto Vega Domínguez 31 698 584 521
Manuela Fernández Hernández 35 636 696 898
Silvia Gracia Barrós 36 654 654 654
La cabecera de esta relación es: PERSONA (NOMBRE, APELLIDOS, EDAD, TELEFONO) El cuerpo es el conjunto de 9 filas con los datos concretos de personas, el grado de la relación es 4 y la cardinalidad 9. Las tablas del modelo relacional cumplen las siguientes propiedades: - No existen filas repetidas: el cuerpo de la relación es un conjunto matemático y en matemáticas, por definición, los conjuntos no incluyen elementos repetidos. Esto se traduce en que dos registros de una misma relación deben diferir, al menos, en el valor de un campo. - Las filas no están ordenadas: esta propiedad muestra la diferencia entre una relación y una tabla, porque las filas de una tabla tienen un orden obvio de arriba hacia abajo, mientras que las filas de una relación no tienen orden. - Los atributos no están ordenados: esto proviene del hecho de que la cabecera de una relación se define también como conjunto. Las columnas de una tabla tienen un orden evidente de izquierda a derecha, pero los atributos de una relación no tienen orden. - Todos los valores de los atributos son atómicos: esto quiere decir que un atributo sólo puede tomar un valor en cada fila. #### Clave primaria y claves ajenas Sea va a recordar lo que era una clave primaria y se va a añadir un concepto nuevo, el de clave ajena. En el modelo relacional tenemos los siguientes tipos de claves: - **Clave candidata**: es un conjunto mínimo y no vacío de atributos que identifica unívocamente cada registro de una relación. - **Clave primaria**: es la clave candidata que elige el usuario para identificar los registros de una relación. Una clave primaria es compuesta cuando está formada por más de un atributo. - **Clave alternativa**: es cualquiera de las claves candidatas que no han sido elegidas como clave primaria. - **Clave ajena**: Es un conjunto no vacío de atributos de una relación cuyos valores han de coincidir con los valores de la clave primaria de otra relación. Las dos relaciones no tienen que ser necesariamente distintas, podrían ser la misma relación (es el caso de las relaciones reflexivas). Un ejemplo a continuación:
**Oficina**
**NUM\_OFICINA** **CALLE** **AREA** **POBLACION** **TELEFONO** **FAX**
001 Rúa Seco, 19 Sur Olite 948 222222 948 658745
002 Larraga, 21 Norte Olite 948 121212 948 123465
003 Tudela, 15 Sur Pamplona 948 323232 948 236589
004 Italia, 12 Centro Zaragoza 976 658745 976 548721
005 de la Parra, 16 Centro Teruel 978 225588 978 159732
El atributo NUM\_OFICINA es una clave candidata ya que identifica de manera única cada registro de la tabla, y en este caso además es la clave primaria porque no existe en la tabla ninguna otra clave candidata.
**Empleado**
**NUM\_EMPLEADO** **DNI** **OFICINA** **TELEF\_FIJO** **TELEF\_MOVIL** **FAX**
12340 25369874 005 978 225588 655 191919 978 159732
12350 72658412 002 948 121212 655 212019 948 123465
12360 72658965 003 948 323232 655 242563 948 236589
12370 25814796 001 976 456985 655 256985 948 658745
12380 25369854 004 976 658745 655 658965 976 548721
En esta tabla hay dos claves candidatas, el atributo NUM\_EMPLEADO y el atributo DNI, ya que ambos identifican de manera única a cada registro de la tabla. Si se considera el atributo DNI como clave primaria, el atributo NUM\_EMPLEADO pasa a ser una clave alternativa de la tabla. Si la relación OFICINA tuviera la siguiente estructura:
**Oficina**
**NUM\_OFICINA** **CALLE** **AREA** **POBLACION** **TELEFONO** **DIRECTOR**
001 Rúa Seco, 19 Sur Olite 948 222222 25369874
002 Larraga, 21 Norte Olite 948 121212 72658412
003 Tudela, 15 Sur Pamplona 948 323232 72658965
004 Italia, 12 Centro Zaragoza 976 658745 72658412
005 de la Parra, 16 Centro Teruel 978 225588 72658965
Se puede ver que el atributo DIRECTOR hace referencia al atributo DNI de la tabla EMPLEADO, que además es la clave primaria de dicha tabla, por lo que DIRECTOR es la clave ajena de la tabla OFICINA y referencia la tabla EMPLEADO. Las claves primarias y ajenas cumplen una serie de propiedades: - Una clave ajena y la clave primaria de la tabla referenciada asociada han de estar definidas sobre los mismos dominios. - Una tabla puede poseer más de una clave ajena. Tendrá una clave ajena por cada tabla referenciada de la cual dependa. - Una tabla puede no tener ninguna clave ajena. - Una clave ajena puede relacionar una tabla consigo misma (relaciones reflexivas). {{@5685}}