Professional Documents
Culture Documents
En el modelo relacional es frecuente llamar tabla a una relacin, aunque para que
una tabla bidimensional sea considerada como una relacin tiene que cumplir con
algunas restricciones:
Tabla de contenidos
1 Terminologa equivalente
2 Claves
o 2.1 Clave ajena
o 2.2 Clave candidata
o 2.3 Clave alternativa
o 2.4 Clave simple
o 2.5 Clave compuesta
3 Formas Normales
o 3.1 Primera Forma Normal (1NF)
o 3.2 Segunda Forma Normal (2NF)
o 3.3 Tercera Forma Normal (3NF)
o 3.4 Cuarta Forma Normal (5NF)
4 Reglas de Codd
5 Vase tambin
6 Enlaces externos
Terminologa equivalente
Dependencia funcional
Una dependencia funcional son conexiones entre uno o ms atributos. Por ejemplo
si conocemos el valor de FechaDeNacimiento podemos conocer el valor de Edad.
Las dependencias funcionales se escriben utilizando una flecha, de la siguiente
manera:
FechaDeNacimiento->Edad
Aqu a FechaDeNacimiento se le conoce como un determinante. Se puede leer de
dos formas FechaDeNacimiento determina a Edad o Edad es funcionalmente
dependiente de FechaDeNacimiento. De la normalizacin (lgica) a la
implementacin (fsica o real) puede ser sugerible tener stas dependencias
funcionales para lograr mayor eficiencia en las tablas.
Dependencia funcional transitiva
Supongamos que en la relacin de la figura 3.0 los estudiantes solo pueden estar
matriculados en un solo curso y supongamos que los profesores solo pueden dar un
curso.
ID_Estudiante -> Curso_Tomando
Curso_Tomando -> Profesor_Asignado
ID_Estudiante -> Curso_Tomando -> Profesor_Asignado
Entonces tenemos que ID_Estudiante determina a Curso_Tomando y el
Curso_Tomando determina a Profesor_Asignado, indirectamente podemos
saber a travs del ID_estudiante el Profesor_Asignado. Entonces en la figura
3.0 tenemos una dependencia transitiva.
Claves
Clave ajena
Cuando se tienen dos tablas o ms, una clave ajena es aquella columna de una
tabla que hace referencia a una clave primaria de otra tabla. Supongamos que
tenemos una base de datos con las dos tablas. Como podemos ver en la tabla de la
figura 4.0 la columna NumeroCliente hace de clave primaria, pero en la tabla de la
figura 5.0 la columna de NumeroCliente hace de clave externa. La clave primaria
NumeroCliente de la figura 4.0 hace referencia a toda la fila, evitando as errores
tipogrficos y ahorrando espacio fsico.
Tambin existe el caso de Relaciones Autoreferenciales. Sucede cuando en la misma
relacin se tiene una clave ajena que hace referencia a la clave primeria de la
misma relacin. Un ejemplo es EMP (NumEmp, Nombre,... ,NumEmp-Ger). En este
caso NumEmp-Ger es una clave ajena que hace referencia a la clave primaria
NumEmp. Por otro lado las claves ajenas pueden tomar valores nulos, como por
ejemplo para un Gerente, el valor NumEmp-Ger sera nulo, ya que no posee
ninguna persona a nivel superior.
Una columna no puede tener multiples valores. Los datos estan atomicos (Si a cada
valor de X le pertenece un valor de Y, entonces a cada valor de Y le pertenece un
valor de X).
La regla de la Primera Forma Normal establece que las columnas repetidas deben
eliminarse y colocarse en tablas separadas
Segunda Forma Normal (2NF)
Dependencia completa. Esta en 2NF si esta en 1NF y si sus atributos no principales
dependen de forma completa de la clave principal. Toda columna que no sea clave
debe depender por completo de la clave primaria. Los atributos dependen de la
clave. Varia la clave y varian los atributos. Dependencia completa. Sus atributos no
principales dependen de forma completa de la clave principal.
Tercera Forma Normal (3NF)
Est en forma normal de Boyce-Codd y se eliminan las dependencias multivaluadas
y se generan todas las relaciones externas con otras tablas u otras bases de datos.
Esta se hace a base de claves
Cuarta Forma Normal (5NF)
Est en cuarta forma normal y toda dependencia-join viene implicada por claves
candidatas.
Reglas de Codd
Codd se dio de cuenta que existan bases de datos en el mercado las cuales decan
ser relacionales, pero lo nico que hacan era guardar la informacin en las tablas,
sin estas tablas estar literalmente normalizadas; entonces ste public 12 reglas
que un verdadero sistema relacional debera de tener, en la prctica algunas de
ellas son difciles de realizar.Un sistema podr considerarse "ms relacional" cuanto
ms siga estas reglas.
Regla No. 1 - La Regla de la informacin
"Toda la informacin en un RDBMS est explcitamente representada de una
sola manera por valores en una tabla".
Cualquier cosa que no exista en una tabla no existe del todo. Toda la
informacin, incluyendo nombres de tablas, nombres de vistas, nombres de
columnas, y los datos de las columnas deben estar almacenados en tablas
dentro de las bases de datos. Las tablas que contienen tal informacin
constituyen el Diccionario de Datos.
Regla No. 2 - La regla del acceso garantizado
quiera que haya cambios en los datos almacenados, o sean cambiados los
mtodos de acceso a los datos".
El comportamiento de los programas de aplicacin y de la actividad de
usuarios va terminales debera ser predecible basados en la definicin lgica
de la base de datos, y ste comportamiento debera permanecer inalterado,
independientemente de los cambios en la definicin fsica de sta.
Regla No. 9 - La regla de independencia lgica
"Los programas de aplicacin y las actividades de acceso por terminal deben
permanecer lgicamente inalteradas cuando quiera que se hagan cambios
(segn los permisos asignados) en las tablas de la base de datos".
La independencia lgica de los datos especifica que los programas de
aplicacin y las actividades de terminal deben ser independientes de la
estructura lgica, por lo tanto los cambios en la estructura lgica no deben
alterar o modificar estos programas de aplicacin.
Regla No. 10 - La regla de la independencia de la integridad
"Todas las restricciones de integridad deben ser definibles en los datos, y
almacenables en el catalogo, no en el programa de aplicacin".
Las reglas de integridad son:
1. Ningn componente de una clave primaria puede tener valores en blanco
o nulos. (esta es la norma bsica de integridad).
2. Para cada valor de clave fornea deber existir un valor de clave primaria
concordante. La combinacin de estas reglas aseguran que haya Integridad
referencial.
Regla No. 11 - La regla de la distribucin
"El sistema debe poseer un lenguaje de datos que pueda soportar que la
base de datos est distribuida fsicamente en distintos lugares sin que esto
afecte o altere a los programas de aplicacin".
El soporte para bases de datos distribuidas significa que una coleccin
arbitraria de relaciones, bases de datos corriendo en una mezcla de distintas
mquinas y distintos sistemas operativos y que este conectada por una
variedad de redes, pueda funcionar como si estuviera disponible como en
una nica base de datos en una sola mquina.
Regla No. 12 - Regla de la no-subversin
"Si el sistema tiene lenguajes de bajo nivel, estos lenguajes de ninguna
manera pueden ser usados para violar la integridad de las reglas y
restricciones expresadas en un lenguaje de alto nivel (como SQL)".
Algunos productos solamente construyen una interfaz relacional para sus
bases de datos No relacionales, lo que hace posible la subversin (violacin)
de las restricciones de integridad. Esto no debe ser permitido.
Modelo relacional
ste es el modelo ms utilizado en la actualidad para modelar problemas reales y
administrar datos dinmicamente.
Tras ser postulados sus fundamentos en 1970 por Edgar Frank Codd, de los
laboratorios IBM en San Jos (California), no tard en consolidarse como un nuevo
paradigma en los modelos de base de datos.
El modelo relacional para la gestin de una base de datos es un modelo de datos
basado en la lgica de predicado y en la teora de conjuntos.
Este modelo considera la base de datos como una coleccin de relaciones. De
manera simple, una relacin representa una tabla, en que cada fila representa una
coleccin de valores que describen una entidad del mundo real. Cada fila se
denomina tupla o registro y cada columna campo.
Entre las ventajas de este modelo estn:
1. Garantiza herramientas para evitar la duplicidad de registros, a travs de
campos claves o llaves.
2. Garantiza la integridad referencial: As al eliminar un registro elimina todos
los registros relacionados dependientes.
3. Favorece la normalizacin por ser ms comprensible y aplicable.
Se basa en describir la informacin usando tablas. Estas tablas se intentan
estructurar de forma que cumplan unos formatos llamados Formas Normales.
Cuanto ms alta la forma normal, ms estrictos son los criterios que cumple la
tabla y ms fcil resulta tratarla.
Estructura de datos
En programacin, una estructura de datos es una forma de organizar un conjunto
de datos elementales (un dato elemental es la mnima informacin que se tiene en
el sistema) con el objetivo de facilitar la manipulacin de estos datos como un todo
o individualmente.
Una estructura de datos define la organizacin e interrelacionamiento de estos, y
un conjunto de operaciones que se pueden realizar sobre l. Las operaciones
bsicas son: