Forma normal de Boyce-Codd
La Forma Normal de Boyce-Codd
(o FNBC) es una forma normal utilizada en la normalización de bases de datos.
Es una versión ligeramente más fuerte de la Tercera forma normal (3FN). La
forma normal de Boyce-Codd requiere que no existan dependencias funcionales no
triviales de los atributos que no sean un conjunto de la clave candidata. En
una tabla en 3FN, todos los atributos dependen de una clave, de la clave
completa y de ninguna otra cosa excepto de la clave (excluyendo dependencias
triviales, como). Se dice que una tabla está en FNBC si y solo si está en 3FN y
cada dependencia funcional no trivial tiene una clave candidata como
determinante. En terminos menos formales, una tabla está en FNBC si está en 3FN
y los únicos determinantes son claves candidatas.
Reglas de Codd
Codd se percató
de que existían bases de datos en el mercado las cuales decían ser
relacionales, pero lo único que hacían era guardar la información en las
tablas, sin estar estas tablas literalmente normalizadas; entonces éste publicó
12 reglas que un verdadero sistema relacional debería tener, en la práctica
algunas de ellas son difíciles de realizar. Un sistema podrá considerarse
"más relacional" cuanto más siga estas reglas.
Regla
No. 1 - La Regla de la información
Toda la
información en un RDBMS está explícitamente representada de una sola manera por
valores en una tabla.
Cualquier
cosa que no exista en una tabla no existe del todo. Toda la información,
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 información constituyen el Diccionario de
Datos. Esto significa que todo tiene que estar almacenado en las tablas.
Toda la
información en una base de datos relacional se representa explícitamente en el
nivel lógico exactamente de una manera: con valores en tablas. Por tanto los
metadatos (diccionario, catálogo) se representan exactamente igual que los
datos de usuario. Y puede usarse el mismo lenguaje (ej. SQL) para acceder a los
datos y a los metadatos (regla 4)
Regla
No. 2 - La regla del acceso garantizado
Cada ítem de
datos debe ser lógicamente accesible al ejecutar una búsqueda que combine el
nombre de la tabla, su clave primaria, y el nombre de la columna.
Esto
significa que dado un nombre de tabla, dado el valor de la clave primaria, y
dado el nombre de la columna requerida, deberá encontrarse uno y solamente un
valor. Por esta razón la definición de claves primarias para todas las tablas
es prácticamente obligatoria.
Regla
No. 3 - Tratamiento sistemático de los valores nulos
La
información inaplicable o faltante puede ser representada a través de valores
nulos
Un RDBMS
(Sistema Gestor de Bases de Datos Relacionales) debe ser capaz de soportar el
uso de valores nulos en el lugar de columnas cuyos valores sean desconocidos.
Regla
No. 4 - La regla de la descripción de la base de datos
La
descripción de la base de datos es almacenada de la misma manera que los datos
ordinarios, esto es, en tablas y columnas, y debe ser accesible a los usuarios
autorizados.
La
información de tablas, vistas, permisos de acceso de usuarios autorizados, etc,
debe ser almacenada exactamente de la misma manera: En tablas. Estas tablas
deben ser accesibles igual que todas las tablas, a través de sentencias de SQL
(o similar).
Regla
No. 5 - La regla del sub-lenguaje Integral
Debe haber al
menos un lenguaje que sea integral para soportar la definición de datos,
manipulación de datos, definición de vistas, restricciones de integridad, y
control de autorizaciones y transacciones.
Esto
significa que debe haber por lo menos un lenguaje con una sintaxis bien
definida que pueda ser usado para administrar completamente la base de datos.
Regla
No. 6 - La regla de la actualización de vistas
Todas las
vistas que son teóricamente actualizables, deben ser actualizables por el
sistema mismo.
La mayoría de
las RDBMS permiten actualizar vistas simples, pero deshabilitan los intentos de
actualizar vistas complejas.
Regla
No. 7 - La regla de insertar y actualizar
La capacidad
de manejar una base de datos con operandos simples aplica no sólo para la
recuperación o consulta de datos, sino también para la inserción, actualización
y borrado de datos'.
Esto
significa que las cláusulas para leer, escribir, eliminar y agregar registros
(SELECT, UPDATE, DELETE e INSERT en SQL) deben estar disponibles y operables,
independientemente del tipo de relaciones y restricciones que haya entre las
tablas o no.
Regla
No. 8 - La regla de independencia física
El acceso de
usuarios a la base de datos a través de terminales o programas de aplicación,
debe permanecer consistente lógicamente cuando quiera que haya cambios en los
datos almacenados, o sean cambiados los métodos de acceso a los datos.
El
comportamiento de los programas de aplicación y de la actividad de usuarios vía
terminales debería ser predecible basados en la definición lógica de la base de
datos, y éste comportamiento debería permanecer inalterado, independientemente
de los cambios en la definición física de ésta.
Regla
No. 9 - La regla de independencia lógica
Los programas
de aplicación y las actividades de acceso por terminal deben permanecer
lógicamente inalteradas cuando quiera que se hagan cambios (según los permisos
asignados) en las tablas de la base de datos.
La
independencia lógica de los datos especifica que los programas de aplicación y
las actividades de terminal deben ser independientes de la estructura lógica,
por lo tanto los cambios en la estructura lógica no deben alterar o modificar
estos programas de aplicación.
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 aplicación.
Las reglas de
integridad
1. Ningún componente de una clave primaria
puede tener valores en blanco o nulos (ésta es la norma básica de integridad).
2. Para cada valor de clave foránea deberá
existir un valor de clave primaria concordante. La combinación de estas reglas
aseguran que haya integridad referencial.
Regla
No. 11 - La regla de la distribución
El sistema
debe poseer un lenguaje de datos que pueda soportar que la base de datos esté
distribuida físicamente en distintos lugares sin que esto afecte o altere a los
programas de aplicación.
El soporte
para bases de datos distribuidas significa que una colección arbitraria de
relaciones, bases de datos corriendo en una mezcla de distintas máquinas y
distintos sistemas operativos y que esté conectada por una variedad de redes,
pueda funcionar como si estuviera disponible como en una única base de datos en
una sola máquina.
Regla
No. 12 - Regla de la no-subversión
.



