




























































































Prepara tus exámenes y mejora tus resultados gracias a la gran cantidad de recursos disponibles en Docsity
Gana puntos ayudando a otros estudiantes o consíguelos activando un Plan Premium
Prepara tus exámenes
Prepara tus exámenes y mejora tus resultados gracias a la gran cantidad de recursos disponibles en Docsity
Prepara tus exámenes con los documentos que comparten otros estudiantes como tú en Docsity
Encuentra los documentos específicos para los exámenes de tu universidad
Estudia con lecciones y exámenes resueltos basados en los programas académicos de las mejores universidades
Responde a preguntas de exámenes reales y pon a prueba tu preparación
Consigue puntos base para descargar
Gana puntos ayudando a otros estudiantes o consíguelos activando un Plan Premium
Comunidad
Pide ayuda a la comunidad y resuelve tus dudas de estudio
Ebooks gratuitos
Descarga nuestras guías gratuitas sobre técnicas de estudio, métodos para controlar la ansiedad y consejos para la tesis preparadas por los tutores de Docsity
Bases de Datos; sistema de recopilación y almacenamiento masivo de datos.
Tipo: Apuntes
1 / 787
Esta página no es visible en la vista previa
¡No te pierdas las partes importantes!





























































































FUNDAMENTOS DE BASES DE DATOS. Cuarta edición
No está permitida la reproducción total o parcial de este libro, ni su tratamiento infor- mático, ni la transmisión de ninguna forma o por cualquier medio, ya sea electrónico, mecánico, por fotocopia, por registro u otros métodos, sin el permiso previo y por escrito de los titulares del Copyright.
DERECHOS RESERVADOS © 2002, respecto a la cuarta edición en español, por McGRAW-HILL/INTERAMERICANA DE ESPAÑA, S. A. U. Edificio Valrealty, 1.aplanta Basauri, 17 28023 Aravaca (Madrid)
Traducido de la cuarta edición en inglés de Database System Concepts
Copyright © MMI, por McGraw-Hill Inc. ISBN: 0-07-228363- ISBN: 84-481-3654- Depósito legal: M.
Editora: Concepción Fernández Madrid Editora de mesa: Susana Santos Prieto Cubierta: DIMA Compuesto en FER Impreso en:
IMPRESO EN ESPAÑA - PRINTED IN SPAIN
VII
PREFACIO, XVII
CAPÍTULO 1 INTRODUCCIÓN, 1
CAPÍTULO 2 MODELO ENTIDAD-RELACIÓN, 19 CAPÍTULO 3 EL MODELO RELACIONAL, 53
CAPÍTULO 4 SQL, 87 CAPÍTULO 5 OTROS LENGUAJES RELACIONALES, 119 CAPÍTULO 6 INTEGRIDAD Y SEGURIDAD, 141 CAPÍTULO 7 DISEÑO DE BASES DE DATOS RELACIONALES, 161
CAPÍTULO 8 BASES DE DATOS ORIENTADAS A OBJETOS, 193 CAPÍTULO 9 BASES DE DATOS RELACIONALES ORIENTADAS A OBJETOS, 211 CAPÍTULO 10 XML, 227
CAPÍTULO 11 ALMACENAMIENTO Y ESTRUCTURA DE ARCHIVOS, 249 CAPÍTULO 12 INDEXACIÓN Y ASOCIACIÓN, 283 CAPÍTULO 13 PROCESAMIENTO DE CONSULTAS, 319 CAPÍTULO 14 OPTIMIZACIÓN DE CONSULTAS, 343
CAPÍTULO 15 TRANSACCIONES, 367 CAPÍTULO 16 CONTROL DE CONCURRENCIA, 383 CAPÍTULO 17 SISTEMA DE RECUPERACIÓN, 413
CAPÍTULO 18 ARQUITECTURAS DE LOS SISTEMAS DE BASES DE DATOS, 445 CAPÍTULO 19 BASES DE DATOS DISTRIBUIDAS, 463 CAPÍTULO 20 BASES DE DATOS PARALELAS, 493
CAPÍTULO 21 DESARROLLO DE APLICACIONES Y ADMINISTRACIÓN, 511 CAPÍTULO 22 CONSULTAS AVANZADAS Y RECUPERACIÓN DE INFORMACIÓN, 537 CAPÍTULO 23 TIPOS DE DATOS AUTOMÁTICOS Y NUEVAS APLICACIONES, 569 CAPÍTULO 24 PROCESAMIENTO AVANZADO DE TRANSACCIONES, 589 CAPÍTULO 25 ORACLE, 611
CAPÍTULO 26 DB2 DE IBM, 629 CAPÍTULO 27 SQL SERVER DE MICROSOFT, 645
BIBLIOGRAFÍA, 673 DICCIONARIO BILINGÜE, 695 ÍNDICE, 771
CONTENIDO BREVE
XI
XVI
XVII
ACERCA DEL AUTOR
A gestión de bases de datos ha evolucionado desde una aplicación informática especia- lizada hasta una parte esencial de un entorno informático moderno y, como resultado, el conocimiento acerca de los sistemas de bases de datos se ha convertido en una parte esencial en la enseñanza de la informática. En este libro se presentan los conceptos fundamen- tales de la administración de bases de datos. Estos conceptos incluyen aspectos de diseño de bases de datos, lenguajes de bases de datos e implementación de sistemas de bases de datos. Este libro está orientado a un primer curso de bases de datos para niveles técnicos y supe- riores. Además del material básico para un primer curso, el texto también contiene temas que pueden usarse como complemento del curso o como material introductorio de un curso avan- zado. En este libro se asume que se dispone de los conocimientos elementales sobre estructuras de datos básicas, organización de computadoras y un lenguaje de programación de alto nivel (tipo Pascal). Los conceptos se presentan usando descripciones intuitivas, muchas de las cuales están basadas en el ejemplo propuesto de una empresa bancaria. Se tratan los resultados teóricos importantes, pero se omiten las demostraciones formales. Las notas bibliográficas contienen referencias a artículos de investigación en los que los resultados se presentaron y probaron, y también referencias a material para otras lecturas. En lugar de demostraciones, se usan figuras y ejemplos para sugerir por qué se espera que los resultados en cuestión sean ciertos. Los conceptos fundamentales y algoritmos tratados en este libro se basan habitualmente en los que se usan en la actualidad en sistemas de bases de datos existentes, comerciales o expe- rimentales. Nuestro deseo es presentar estos conceptos y algoritmos como un conjunto general que no esté ligado a un sistema de bases de datos particular. En la Parte 8 se discuten detalles de sistemas de bases de datos comerciales. En esta cuarta edición de Fundamentos de bases de datos se ha mantenido el estilo global de las primeras tres ediciones, a la vez que se ha tenido en cuenta la evolución de la gestión de bases de datos. Se han añadido varios capítulos nuevos para tratar nuevas tecnologías. Cada capítulo se ha corregido y la mayoría se ha modificado ampliamente. Se describirán los cam- bios con detalle en breve.
ORGANIZACIÓN
El texto está organizado en ocho partes principales más dos apéndices:
- Visión general (Capítulo 1). En el Capítulo 1 se proporciona una visión general de la natu- raleza y propósito de los sistemas de bases de datos. Se explica cómo se ha desarrollado el concepto de sistema de bases de datos, cuáles son las características usuales de los sistemas de bases de datos, lo que proporciona al usuario un sistema de bases de datos y cómo un sis- tema de bases de datos se comunica con los sistemas operativos. También se introduce una aplicación de bases de datos de ejemplo: una empresa bancaria que consta de muchas sucur- sales. Este ejemplo se usa a lo largo de todo el libro. Este capítulo es histórico, explicativo y motivador por naturaleza. - Modelos de datos (Capítulos 2 y 3). En el Capítulo 2 se presenta el modelo entidad-relación. Este modelo proporciona una visión de alto nivel de los resultados de un diseño de base de datos y de los problemas que se encuentran en la captura de la semántica de las aplicaciones realistas que contienen las restricciones de un modelo de datos. El Capítulo 3 se centra en el modelo de datos relacional, tratando la relevancia del álgebra relacional y el cálculo rela- cional. - Bases de datos relacionales (Capítulos 4 al 7). El Capítulo 4 se centra en el lenguaje rela- cional orientado al usuario de mayor influencia: SQL. El Capítulo 5 cubre otros dos lengua- jes relacionales, QBE y Datalog. En estos dos capítulos se describe la manipulación de datos: consultas, actualizaciones, inserciones y borrados. Los algoritmos y las cuestiones de diseño
PREFACIO
XIX
técnicas de consulta, incluyendo sistemas de ayuda a la toma de decisiones y recuperación de la información. Los temas tratados en el área de la ayuda a la toma de decisiones incluyen las técnicas de procesamiento analítico interactivo (OLAP, Online Analytical Processing), el soporte de SQL:1999 para OLAP, recopilación de datos y almacenes de datos. El capítulo también describe técnicas de recuperación de información para la consulta de datos textua- les, incluyendo técnicas basadas en hipervínculos usadas en los motores de búsqueda Web. El Capítulo 23 trata tipos de datos avanzados y nuevas aplicaciones, incluyendo datos tem- porales, datos espaciales y geográficos, datos multimedia, y aspectos de la gestión de las bases de datos móviles y personales. Finalmente, el Capítulo 24 trata el procesamiento avanzado de transacciones. Se estudian los monitores de procesamiento de transacciones, los sistemas de transacciones de alto rendimiento, los sistemas de transacciones de tiempo real, y los flu- jos de datos transaccionales.
- Estudios de casos (Capítulos 25 al 27). En esta parte presentamos estudios de casos de tres sistemas de bases de datos comerciales: Oracle, IBM DB2 y Microsoft SQL Server. Estos capítulos esbozan características únicas de cada uno de los productos y describen su estruc- tura interna. Proporcionan una gran cantidad de información interesante sobre los productos respectivos, y ayudan a ver cómo las diferentes técnicas de implementación descritas en las partes anteriores se usan en sistemas reales. También se tratan aspectos prácticos en el diseño de sistemas reales. - Apéndices en línea. Aunque la mayoría de las aplicaciones de bases de datos modernas usen, bien el modelo relacional o bien el modelo orientado a objetos, los modelos de datos de redes y jerárquico están en uso todavía. En beneficio de los lectores que deseen aprender estos modelos de datos se proporcionan apéndices que describen los modelos de redes y jerárquico, en los Apéndices A y B, respectivamente. Los apéndices sólo están disponibles en Internet (http://www.bell-labs.com/topic/books/db-book). El Apéndice C describe el diseño avanzado de bases de datos relacionales, incluyendo la teoría de dependencias multivaloradas ¿Multivaluadas?, las dependencias de reunión y las formas normales de proyección-reunión y dominio-clave. Este apéndice es útil para quienes deseen el tratamiento del diseño de bases de datos relacionales en más detalle, y para profe- sores que deseen explicarlo en sus asignaturas. Este apéndice está también sólo disponible en Internet, en la página Web del libro.
LA CUARTA EDICIÓN
La producción de esta cuarta edición se ha guiado por muchos comentarios y sugerencias refe- ridos a las ediciones anteriores, junto con las propias observaciones en la enseñanza en el IIT de Bombay, y por el análisis de las direcciones que la tecnología de bases de datos está tomando. El procedimiento básico fue reescribir el material en cada capítulo, actualizando el material más antiguo, añadiendo discusiones en desarrollos recientes en la tecnología de bases de datos, y mejorando las descripciones de los temas que los estudiantes encontraron difíciles de com- prender. Cada capítulo tiene ahora una lista de términos de repaso, que pueden ayudar a asi- milar los temas clave tratados en cada capítulo. Se ha añadido también una nueva sección al final de la mayoría de los capítulos que proporciona información sobre herramientas software referidas al tema del capítulo. También se han añadido nuevos ejercicios y se han actualizado las referencias. Se ha incluido un nuevo capítulo que trata XML, y tres capítulos de estudio de los sistemas de bases de datos comerciales líderes: Oracle, IBM DB2 y Microsoft SQL Server. Los capítulos se han organizado en varias partes y se han reorganizado los contenidos de varios de ellos. En beneficio de aquellos lectores familiarizados con la tercera edición se expli- can a continuación los principales cambios.
- Modelo entidad-relación. Se ha mejorado el tratamiento del modelo entidad-relación (E-R). Se han añadido nuevos ejemplos y algunos se han cambiado para dar una mejor intuición al lector. Se ha incluido un resumen de notaciones E-R alternativas, junto con un nuevo apar- tado sobre UML. - Bases de datos relacionales. El tratamiento de SQL en el Capítulo 4 ahora se refiere al están- dar SQL:1999, que se aprobó después de la publicación de la tercera edición de este libro. El
PREFACIO
XX
tratamiento de SQL se ha ampliado significativamente para incluir la cláusula with , para un tratamiento ampliado de SQL incorporado y el tratamiento de ODBC y JDBC, cuyo uso ha aumentado notablemente en los últimos años. La parte del capítulo 5 dedicada a Quel se ha eli- minado, ya que no se usa ampliamente debido al poco uso que actualmente se hace de este lenguaje. El tratamiento de QBE se ha revisado para eliminar algunas ambigüedades y para añadir el tratamiento de la versión de QBE usada en la base de datos Microsoft Access. El Capítulo 6 trata ahora de las restricciones de integridad y de la seguridad. El tratamiento de la seguridad, ubicado en la edición anterior en el Capítulo 19, se ha trasladado al Capítu- lo 6. El Capítulo 6 también trata los disparadores. El Capítulo 7 aborda el diseño de las bases de datos relacionales y las formas normales. La discusión de las dependencias funcionales, ubicada en la edición anterior en el Capítulo 6, se ha trasladado al Capítulo 7. El Capítulo 7 se ha remodelado significativamente, proporcionando varios algoritmos para las dependen- cias funcionales y un tratamiento extendido del proceso general del diseño de bases de datos. Los axiomas para la inferencia de las dependencias multivaloradas, las formas normales FNRP y FNCD se han trasladado al apéndice.
- Bases de datos basadas en objetos. Se ha mejorado el tratamiento de la orientación a obje- tos del Capítulo 8, y se ha actualizado la discusión de ODMG. Se ha actualizado el trata- miento de las bases de datos relacionales orientadas a objetos del Capítulo 9 y, en particular, el estándar SQL:1999, reemplaza a SQL extendido usado en la tercera edición. - XML. El Capítulo 10, que trata XML, es un nuevo capítulo de la cuarta edición. - Almacenamiento, indexación y procesamiento de consultas. Se ha actualizado el trata- miento del almacenamiento y de las estructuras de archivos del Capítulo 11; este fue el Capí- tulo 10 en la tercera edición. Muchas características de las unidades de disco y de otros mecanismos de almacenamiento han cambiado en gran medida con el paso de los años, y su tratamiento se ha actualizado correspondientemente. El tratamiento de RAID se ha actuali- zado para reflejar las tendencias tecnológicas. El tratamiento de diccionarios de datos (catá- logos) se ha extendido. El Capítulo 12, sobre indexación, incluye ahora el estudio de los índices de mapa de bits; este capítulo fue el Capítulo 11 en la tercera edición. El algoritmo de inserción en árboles B+ se ha simplificado y se ha proporcionado un pseudocódigo para su examen. La asociación dividida se ha eliminado, ya que no tiene un uso significativo. El tratamiento del procesamiento de consultas se ha reorganizado, con el capítulo anterior (Capítulo 12 en la tercera edición) dividido en dos capítulos, uno sobre procesamiento de consultas (Capítulo 13) y otro sobre optimización de consultas (Capítulo 14). Todos los deta- lles referidos a la estimación de costes y a la optimización de consultas se han trasladado al Capítulo 14, permitiendo al Capítulo 13 centrarse en los algoritmos de procesamiento de con- sultas. Se han eliminado varias fórmulas detalladas (y tediosas) para el cálculo del número exacto de operaciones de E/S para diferentes operaciones. El Capítulo 14 se presenta ahora con un pseudocódigo para la optimización de algoritmos, y nuevos apartados sobre la opti- mización de subconsultas anidadas y sobre vistas materializadas. - Procesamiento de transacciones. El Capítulo 15, que proporciona una introducción a las transacciones, se ha actualizado; este capítulo era el Capítulo 13 en la tercera edición. Se han eliminado los tests de secuenciabilidad. El Capítulo 16, sobre el control de concurrencia, incluye un nuevo apartado sobre la imple- mentación de los gestores de bloqueo, y otro sobre los niveles débiles de consistencia, que estaban en el Capítulo 20 de la tercera edición. Se ha ampliado el control de concurrencia de estructuras de índices, proporcionando detalles del protocolo cangrejo, que es una alterna- tiva más simple al protocolo de enlace B, y el bloqueo de siguiente clave para evitar el pro- blema fantasma. El Capítulo 17, que trata sobre recuperación, incluye ahora un estudio del algoritmo de recuperación ARIES. Este capítulo trata ahora los sistemas de copia de seguri- dad remota para proporcionar una alta disponibilidad a pesar de los fallos, característica cada vez más importante en las aplicaciones «24×7». Como en la tercera edición, esta organización permite a los profesores elegir entre con- ceptos de procesamiento de transacciones introductorios únicamente (cubiertos sólo en el Capítulo 15) u ofrecer un conocimiento detallado (basado en los Capítulos 15 al 17). - Arquitecturas de sistemas de bases de datos. El Capítulo 18, que proporciona una visión general de las arquitecturas de sistemas de bases de datos, se ha actualizado para tratar la tec- nología actual; esto se encontraba en el Capítulo 16 de la tercera edición. El orden del capí-
PREFACIO