Guía de Ejercicios de Normalización de Base de DatosUNEFA Guía de Ejercicios Aplicar las reglas de normalización los siguientes ejercicios. 1. Un dato sin normalizar no cumple con ninguna regla de normalización. Para explicar con un ejemplo en qué consiste cada una de las reglas, vamos a considerar los datos de la siguiente tabla. ordenes (id_orden, fecha, id_cliente, nom_cliente, estado, num_art, nom_art, cant, precio) Ordenes Id_orden 2301 2301 2301 2302 2303 2303 Fecha 23/02/11 23/02/11 23/02/11 25/02/11 27/02/11 27/02/11 Id_cliente Nom_cliente 101 Martin 101 Martin 101 Martin 107 Herman 110 Pedro 110 Pedro Estado Caracas Caracas Caracas Coro Maracay Maracay Num_art 3786 4011 9132 5794 4011 3141 nom_art Red Raqueta Paq-3 Paq-6 Raqueta Funda cant 3 6 8 4 2 2 Precio 35,00 65,00 4,75 5,00 65,00 10,00 PRIMERA FORMAL NORMAL (1FN) Al examinar estos registros, podemos darnos cuenta que contienen un grupo repetido para NUM_ART, NOM_ART, CANT y PRECIO. La 1FN prohíbe los grupos repetidos, por lo tanto tenemos que convertir a la primera forma normal. Los pasos a seguir son: • Tenemos que eliminar los grupos repetidos. • Tenemos que crear una nueva tabla con la PK de la tabla base y el grupo repetido. Los registros quedan ahora conformados en dos tablas que llamaremos ORDENES y ARTICULOS_ORDENES ordenes (id_orden, fecha, id_cliente, nom_cliente, estado) Articulos_ordenes (id_orden, num_art, nom_art, cant, precio) Ordenes Id_orden 2301 2302 2303 Fecha 23/02/11 25/02/11 27/02/11 Id_cliente Nom_cliente 101 Martin 107 Herman 110 Pedro Estado Caracas Coro Maracay Articulos_ordenes Id_orden Num_art 2301 3786 2301 4011 2301 9132 2302 5794 2303 4011 2303 3141 nom_art Red Raqueta Paq-3 Paq-6 Raqueta Funda cant 3 6 8 4 2 2 Precio 35,00 65,00 4,75 5,00 65,00 10,00 Prof. Wilfredo Diaz Página 1/9 Articulos_ordenes (id_orden. pero no son dependientes de ID_ORDEN. Lo que haremos a continuación es eliminar estas columnas de la tabla ARTICULOS_ORDENES y crear una tabla ARTICULOS con dichas columnas y la llave primaria de la que dependen. • Eliminar esas columnas de la tabla base. num_art. Por su parte. La tabla ORDENES está en 2FN.Guía de Ejercicios de Normalización de Base de Datos SEGUNDA FORMAL NORMAL (2FN) UNEFA Ahora procederemos a aplicar la segunda formal normal. Por lo tanto. es decir. Los pasos a seguir son: • Determinar las columnas que son dependientes de otra columna no llave. • Crear una segunda tabla con esas columnas y la(s) columna(s) de la PK de la cual dependen. • Eliminar esas columnas de la tabla base. Wilfredo Diaz . precio) Articulos Num_art 3786 4011 9132 5794 3141 nom_art Red Raqueta Paq-3 Paq-6 Funda Precio 35. Las tablas quedan ahora de la siguiente manera.00 4. cant) Articulos_ordenes Id_orden Num_art 2301 3786 2301 4011 2301 9132 2302 5794 2303 4011 2303 3141 cant 3 6 8 4 2 2 Articulos ( num_art. Cualquier valor único de ID_ORDEN determina un sólo valor para cada columna.00 65. la tabla ARTICULOS_ORDENES no se encuentra en 2FN ya que las columnas PRECIO y NOM_ART son dependientes de NUM_ART.00 TERCERA FORMAL NORMAL (3FN) La tercera forma normal nos dice que tenemos que eliminar cualquier columna no llave que sea dependiente de otra columna no llave. Página 2/9 Prof. todas las columnas son dependientes de la llave primaria ID_ORDEN.75 5. tenemos que eliminar cualquier columna no llave que no dependa de la llave primaria de la tabla. nom_art.00 10. Los pasos a seguir son: • Determinar cuáles columnas que no son llave no dependen de la llave primaria de la tabla. CANT_PROD) Prof. Para normalizar esta tabla. FACTURA DE COMPRA VENTA: La empresa COLOMBIAN SYSTEMS lo ha contratado como el “Ingeniero Encargado” para sistematizar la facturación. estado) Articulos ( num_art.Guía de Ejercicios de Normalización de Base de Datos UNEFA • Crear una segunda tabla con esas columnas y con la columna no llave de la cual son dependientes. cant) 2. NOM_CLIENTE. FECHA_FAC. hasta llegar a la Tercera Forma Normal. CIUDAD_CLIENTE. id_cliente) Clientes (id_cliente. COD_PROD. nos damos cuenta que tanto la tabla ARTICULOS. DESP_PROD. id_cliente) Ordenes Id_orden 2301 2302 2303 Fecha 23/02/11 25/02/11 27/02/11 Id_cliente 101 107 110 Clientes (id_cliente. Wilfredo Diaz Página 3/9 . precio) Articulos_ordenes (id_orden. estado) Ordenes Id_cliente Nom_cliente 101 Martin 107 Herman 110 Pedro Estado Caracas Coro Maracay Por lo tanto la base de datos queda de la siguiente manera: ordenes (id_orden. ya que NOM_CLIENTE y ESTADO son dependientes de ID_CLIENTE. DIR_CLIENTE. CATEGORIA. ordenes (id_orden. Las nuevas tablas CLIENTES y ORDENES se muestran a continuación. num_art. como la tabla ARTICULOS_ORDENES se encuentran en 3FN. Al observar las tablas que hemos creado. usted debe analizar toda la información disponible y aplique el proceso de normalización. TELEF_CLIENTE. nom_art. RIF_CLIENTE. moveremos las columnas no llave y la columna llave de la cual dependen dentro de una nueva tabla CLIENTES. fecha. Sin embargo la tabla ORDENES no lo está. y esta columna no es la llave primaria. nom_cliente. nom_cliente. Factura(NUM_FAC. Se pide realizar la respectiva justificación detallada de cada uno de los pasos que conduzcan al resultado final. En la siguiente FACTURA DE COMPRA VENTA. VAL_UNIT. fecha. Donde se incluyen los nombres de los atributos con su significado * GUIA_NO = Numero de Guia * GUIA_FECHA= Fecha de la Guia * GUIA_HORA= Hora de la Guia * ORGN_RIF = Identificacion de Empresa Origen * ORGN_NOM = Nombre de Empresa Origen * ORGN_ACT = Actividad Comercial de Empresa Origen * ORGN_CIUDAD= Ciudad de Empresa Origen * ORGN_DIR = Direccion de Empresa Origen * ORGN_TEL = Telefono de Empresa Origen * ORGN_CEL = Celular de Empresa Origen * DEST_ID = Identificacion del destinatario * DEST_NOM = Nombre del destinatario * DEST_COD_CIUDAD = Codigo de la ciudad del destinatario * DEST_CIUDAD= Ciudad del destinatario * DEST_DIR = Direccion del destinatario * DEST_TEL = Telefono del destinatario * DEST_KM = Distancia kilometraje de Ciudad origen a ciudad del destinatario * CODIGO = Codigo del paquete * TIPO = Tipo de paquete * NOMBRE = Nombre del paquete * DESCRIPCION = Descripción del paquete * VALR_ FLETE = Valor del flete Prof.Guía de Ejercicios de Normalización de Base de Datos Donde: NUM_FAC: Número de la factura de compra venta FECHA_FAC: Fecha de la factura de compra venta NOM_CLIENTE: Nombre del cliente DIR_CLIENTE: Dirección del cliente RIF_CLIENTE: Rif del cliente CIUDAD_CLIENTE: Ciudad del cliente TELEF_CLIENTE: Teléfono del cliente CATEGORIA: Categoría del producto COD_PROD: Código del producto DESCRIPCION: Descripción del producto VAL_UNIT: Valor unitario del producto CANT_PROD: Cantidad de productos q compra el cliente La llave primaria es Número de Factura de venta: NUM_FAC UNEFA 3. EMPRESA DE ENVIO DE MERCANCIA: a continuación se agrupan todos los atributos que hacen parte de la base de datos para aplicarle las reglas de normalización. Wilfredo Diaz Página 4/9 . Wilfredo Diaz Página 5/9 . categoría. num_copias. titulo. teléfono y dirección. nom_cliente. y su fecha de nacimiento. cada miembro del club tiene asignado un número de membresía. Un casete puede venir en varios formatos y una película es grabada en un solo casete. cod_cassette. a los clientes de la tienda le gusta conocer datos como el nombre real del actor. cuando un cliente alquila un casete se debería conocer el nombre de la película. Solo se alquila videos a aquellos que pertenecen al club de videos. Para pertenecer al club se debe tener un buen crédito. num_membresia. Se pide aplicar las reglas de normalización hasta la tercera forma normal. valor_alquiler. etc. cod_tipo) Donde: cod_alquiler = Codigo del alquiler num_membresia = Numero de membresia cod_cliente = código del cliente nom_cliente = nombre del cliente dir_cliente = dirección del cliente telef_cliente = teléfono del cliente cod_cassette = código del cassette fecha_alquiler = fecha del alquiler del al película fecha_dev = fecha de devolución de la pelicula valor_alquiler = valor del alquiler de la película cantidad = cantidad de película alquilada num_copias = números de copias de cassette formato = formato del cassette titulo = nombre de la película categoría = categoría de la película cod_actor = código del actor nom_actor = nombre del actor fechanac_actor = fecha de nacimiento del actor cod_tipo = código del tipo de película. fecha_dev. suspenso. Por cada miembro del club se mantiene una ficha con su nombre. Video club: En una tienda de video se necesita mantener información de alrededor de 3000 casetas cada uno de los casetes tiene asignado un número por cada `película se necesita conocer un titulo y categoría por ejemplo: comedia. frecuentemente las películas son pedidas de acuerdo a un actor especifico Tom Cruise y Demi More son los más populares es por esto que se debe mantener información de los actores que pertenecen a cada película. cod_pelicula. cod_actor. nom_actor. telef_cliente. cantidad) Cassettte (cod_cassette.Guía de Ejercicios de Normalización de Base de Datos UNEFA 4. En la tienda se mantienen información solo de los actores que aparecen en las películas y que se tiene a disposición. fechanac_actor. Se mantienen algunas copias de muchas películas. fecha_alquiler. cod_cliente. formato. la fecha en la que se alquila y la fecha de devolución. drama. Prof. Se desea mantener información de todos los casetes que un cliente alquila. Se le da a cada película una identificación y se mantiene seguimiento de lo que contiene cada casete. dir_cliente. No en todas las películas actúan artistas famosos. teniendo las siguientes entidades con sus respectivos atributos: Alquiler (cod_alquiler. acción. ciencia ficción. editorial. Wilfredo Diaz Se pide: ¿En qué forma normal se encuentra la relación? ¿Por qué? Página 6/9 . atributos principales. curso.Guía de Ejercicios de Normalización de Base de Datos UNEFA 5. Dada la siguiente relación PRESTAMO_LIBROS (Colegio.P Cervantes Andrés Fernández Ingles 1.A01 1er Grado 05/05/2010 C.P Cervantes Juan Pérez 1. libro.B01 1er Grado Temas de Hoy 18/12/2010 C. profesor.N56 Aprender y Enseñar en educación infantil Educación Infantil N9 Aprender y enseñar en educación infantil Aprender y enseñar en educación infantil Saber educar: guía para Padres y Profesores Saber educar: guía para Padres y Profesores Aprender y enseñar en educación infantil Editorial Fecha_prestamo C.A01 2do Grado Temas de Hoy 05/05/2010 C. Colegio Profesor Asignatura/ habilidad Pensamiento Lógico Escritura Pensamiento Numérico Pensamiento Espacial.A01 2do Grado Graó 09/09/2010 C. cod_viaje. Temporal y causal Pensamiento Numérico Aula Curso Libro Aprender y enseñar en educación infantil Preescolar Rubio.P Cervantes Juan Pérez 1. gasto_total) en la que se cumplen las siguientes dependencias funcionales: Cod_empleado Gasto_total Cod_viaje Destino Prof. fecha_prestamo) que contiene información relativa a los prestamos que realizan las editoriales a los profesores de primaria de los colegios para su evaluación en alguna de las asignaturas/habilidades que imparten.P Cervantes Andrés Fernández Escritura 1.A01 1er Grado 05/05/2010 C. asignatura_habilidad. Dada la relación GASTOS_EMPLEADOS (cod_empleado.P Cervantes Juan Pérez 1. Se pide aplicar las reglas de normalización y obtener su modelo relacional. aula.B01 1er Grado Graó 06/05/2010 6.A01 1er Grado Graó Técnicas Rubio Graó 09/09/2010 C.B01 1er Grado Graó 06/05/2010 C.B01 1er Grado Prentice Hall 06/05/2010 C.P Cervantes Alicia García 1. destino.P Quevedo Juan Méndez Pensamiento Lógico 2. indicar sus claves.P Quevedo Juan Méndez Pensamiento Numérico 2.P Cervantes Alicia García 1. Martínez F. Wilfredo Diaz Página 7/9 . Se presenta una base de datos de una biblioteca. considerando únicamente la extensión de la relación mostrada en la tabla: a.01 Autor Murray Spiegel E.1. Indicar un ejemplo de anomalía de borrado Prof. Indicar un ejemplo de anomalía de modificación b.A10 2.B05 2. aplicar las reglas de normalización simplificando hasta la tercera forma normal. sección) se pide aplicar las reglas de normalización llegando hasta las 3FN. UTILIZACIÓN DE RECURSOS DE LA UNIVERSIDAD: Dada la siguiente relación UTILIZACIÓN (DNI_Prof. Cuadra P. Autor. Martínez Despacho_Prof 2.2. Petroustsos Murray Spiegel Nancy Greenberg y Priya Nathan Ramalho Editorial McGraw Hill Anaya McGraw Hill Oracle Corp. Juan Fechadev 15/04/2005 17/04/2005 16/04/2005 20/04/2005 18/04/2005 9. Prestamos_libro (codLibro. Fechadev) codLibro 1001 1004 1005 1006 1007 Titulo Variable compleja Visual Basic 5 Estadística Oracle University Clipper 5. Castro D.2. René García Roque. Moreno P. código_curso. Juan Ríos Terán.1. Editorial. Martínez E. Recurso. nombre_curso. Código/ alumno 382145A 382145A 382145A 360247k 360247k 360247k Nombre/ alumno Luis Zuloaga Luis Zuloaga Luis Zuloaga Raúl Rojas Raúl Rojas Raúl Rojas Especialidad Industrial Industrial Industrial Sistemas Sistemas Sistemas Código/ curso MA123 QU514 AU521 PA714 MA123 AU511 Nombre_curso Matemática 2 Física Química Descriptiva Investigación 1 Matemática 2 Dibujo Nombre/ docente Carlos Arambulo Petra Rondinel Víctor Moncada Cesar Fernadez Carlos Arambulo Víctor Moncada Oficina CB-214 CB-110 CB-120 SC-220 CB-214 CB-120 curso U U W V V U 8.B05 Recurso R122 R100 R200 R122 R200 R300 R300 R122 Descripción Tablet PC Impresora Portátil Tablet PC Portátil Scaner Scaner Tablet PC Fecha_inicio 1-1-2007 1-1-2007 12-1-2007 16-1-2007 23-1-2007 1-1-2007 1-2-2007 1-2-2007 Fecha_fin 15-1-2007 15-1-2007 22-1-2007 31-1-2007 26-1-2007 15-1-2007 6-2-2007 6-2-2007 Se pide.2.) que contiene información relativa a la utilización de los recursos de la universidad por parte de los profesores en periodos de tiempo: DNI_Prof 33456456 44556689 33456456 11223344 99771122 33456456 99887766 33456456 Nombre_Prof P. Martínez L. Luis Pérez Gómez. Nombre_Prof. Se tiene una relación del REPORTE_MATRICULA (código_alumno. nombre_alumno.2.B23 2.B05 2. Despacho_Prof. Fecha_inicio.2. Ubicación. especialidad. Fecha_fin. Calle P.B23 2. nombre_docente. NombreLector. Titulo. McGraw Hill nombreLector Pérez Gómez.C11 2. oficina.Guía de Ejercicios de Normalización de Base de Datos UNEFA 7.B05 2.2. Ana Roca. Alcorcón Pl. Martín E. Mayor. Monte E. c. Alcorcón Avd. Martín Código_Tienda 100A 100A 100A 200B 300C 200B 300C 100A 100A 200B Dirección _Tienda Avd. Nombre (N). Alcorcón Turno M M T T M M M M T M Fecha 2/9/06 2/9/06 2/9/06 3/9/06 3/9/06 3/9/06 4/9/06 4/9/06 4/9/06 5/9/06 Se pide. considerando que los nombres de los monitores no son únicos y los nombres de las actividades tampoco y ateniéndose a las tuplas de la relación SE REALIZA: Prof. Código_Tienda (C). Alcorcón C/ Sur 13. Alcorcón Pl. Nombre_monitor. 23. Código_Tienda. Central. Central. Nombre. Wilfredo Diaz Página 8/9 . López F. Mayor. 23. Dirección_Tienda. Fecha. Indicar un ejemplo de anomalía de borrado b. Monte L. Getafe Avd.Guía de Ejercicios de Normalización de Base de Datos c. Aplicar la normalización correspondiente UNEFA 10. Martín L. Indicar un ejemplo de anomalía de inserción d. Mayor. 23. Alcorcón C/ Sur 13. Alcorcón Avd. Sanz P. ¿En qué Forma Normal se encuentra la relación? ¿Cuáles son sus claves? 11. Fecha (F). Alcorcón Avd. Hora_F) utilizada para almacenar información sobre la fecha y duración de las actividades deportivas que se organizan en un colegio Se pide: Se pide. TURNOS DE TRABAJO: Dada la siguiente relación ASIGNACIÓN (DNI. López F. Díaz P. DNI_Monitor. Indicar las dependencias funcionales utilizando las siguientes abreviaturas: DNI (P). Mayor. 23. Fecha. Mayor. Getafe C/ Sur 13. ACTIVIDADES DEPORTIVAS: Dada la siguiente relación SE REALIZA(Cod_Actividad. Dirección_Tienda (D). Sala. Turno (T). 23. considerando únicamente la extensión de la relación mostrada en la tabla : a. Hora_I. Turno) que contiene información relativa a la asignación de los turnos de trabajo de los empleados de los distintos centros de una cadena de tiendas de moda: DNI 33456456 44556689 99771122 33456456 11223344 99887766 11223344 99887766 44556689 33456456 Nombre P. Nombre_Actividad. Sanz D. Hora_F(E). Fecha(F). c.Guía de Ejercicios de Normalización de Base de Datos a. ¿Cuáles son las claves de la relación? ¿En que FN está la relación SE REALIZA? ¿por qué? UNEFA Prof. Wilfredo Diaz Página 9/9 . Indicar un ejemplo de anomalía de borrado b. Indicar las dependencias funcionales utilizando las siguientes abreviaturas: Cod_Actividad (A). Sala (S). Hora_I (I). DNI_Monitor (D). Nombre_Actividad (N). Nombre_Monitor(M).
Report "Guía de Ejercicios de Normalización de Base de Datos"