Software Libre - UOC

Transcription

Software libreRafael Camps ParéLuis Alberto Casillas SantillánDolors Costal CostaMarc Gibert GinestàCarme Martín EscofetOscar Pérez Mora71Z799014MOBases de datosUF o r ma ci ó n d e Po s gr a d o

FUOC 71Z799014MO2Bases de datosDavid Megías JiménezJordi Mas HernándezRafael Camps ParéCoordinadorCoordinadorAutorIngeniero de Informática por la UAB.Coordinador general de Softcatalà ydesarrollador del procesador de textoslibre Abiword.Profesional informático en varias empresas.Ha sido profesor universitario en la Facultadde Informática de Barcelona de laUniversidad Politécnica de Cataluña.Actualmente está adscrito a la EscuelaUniversitaria Politécnica de Vilanovai la Geltrú.Magíster en Técnicas Avanzadas deAutomatización de Procesos por la UAB.Doctor en Informática por la UAB.Profesor de los Estudios de Informáticay Multimedia de la UOC.Miembro fundador de Softcatalày de la red telemática RedBBS.En calidad de consultor, ha trabajadoen empresas como Menta, Telépolis,Vodafone, Lotus, eresMas, Amena y TerraEspaña.Luis Alberto Casillas SantillánDolors Costal CostaMarc Gibert GinestàAutorAutoraAutorLicenciado en Informática (1995), maestroen Sistemas (1998), doctorante enIngeniería y Tecnología (2003), estáestudiando el doctorado en la UOC.Profesor universitario desde marzo de1995. Investigador en Inteligencia Artificialdesde 1998. Consultor Universitario paracuestiones educativas.Doctora en Informática por la UniversidadPolitécnica de Cataluña. Profesora titulardel Departamento de Lenguajes y SistemasInformáticos de la Universidad Politécnicade Cataluña, asignada a la Facultadde Informática de Barcelona.Ingeniero en Informática por la UniversidadRamon Llull. Sociofundador y jefe de proyectos de CometaTechnologies, empresa dedicadaa dar soluciones en tecnologías dela información, basadas en el uso deestándares y herramientas de códigoabierto. Profesor del Máster en Seguridaden Tecnologías de la Información enEnginyeria y Arquitectura La Salle yconsultor del Master Internacionalen Software Libre de la UOC.Carme Martín EscofetOscar Pérez MoraAutoraAutorLicenciada en Informática por laUniversidad Politécnica de Cataluña.Profesora de la asignatura Introduccióna las bases de datos en la Facultadde Informática de Barcelona, y de laasignatura Sistemas orientados a basesde datos en la Facultad de Matemáticas yEstadística. También ha sido profesorade las asignaturas Diseño de sistemasy Gestión de sistemas informáticosen la Escuela Universitaria Politécnicade Vilanova i la Geltrú.Ingeniero en Comunicaciones yElectrónica por la Universidad deGuadalajara (México) y Maestro enSistemas de Información. Ha participadoen diversas publicaciones e impartidocursos especializados. MiembroFundador del Marichi del SUTUdeGy del Grupo Linux de Occidente A. C.(www.glo.org.mx). Organizador delFestival GNU/Linux y Software era edición: mayo 2005 Fundació per a la Universitat Oberta de CatalunyaAv. Tibidabo, 39-43, 08035 BarcelonaMaterial realizado por Eureca Media, SL Autores: Rafael Camps Paré, Luis Alberto Casillas Santillán, Dolors Costal Costa, Marc Gibert Ginestà,Carme Martín Escofet, Oscar Pérez MoraDepósito legal: B-15.562-2005ISBN: 84-9788-269-5Se garantiza permiso para copiar, distribuir y modificar este documento según los términos de la GNU Free Documentation License,Version 1.2 o cualquiera posterior publicada por la Free Software Foundation, sin secciones invariantes ni textos de cubierta delanterao trasera. Se dispone de una copia de la licencia en el apartado “GNU Free Documentation License” de este documento.

FUOC 71Z799014MO3AgradecimientosLos autores agradecen a la Fundación para la Universitat Oberta de Catalunya(http://www.uoc.edu) la financiación de la primera edición de esta obra, enmarcada en el Máster Internacional en Software Libre ofrecido por la citadainstitución.El autor Óscar Pérez Mora desea hacer constar el agradecimiento siguiente: “AJosé Pérez Arias, gracias por haber sido mi padre”, en memoria de su padre fallecido durante la realización de este material.Bases de datos

FUOC 71Z799014MO5IntroducciónLas bases de datos son el método preferido para el almacenamiento estructurado de datos. Desde las grandes aplicaciones multiusuario, hasta los teléfonosmóviles y las agendas electrónicas utilizan tecnología de bases de datos para asegurar la integridad de los datos y facilitar la labor tanto de usuarios como de losprogramadores que las desarrollaron.Desde la realización del primer modelo de datos, pasando por la administración del sistema gestor, hasta llegar al desarrollo de la aplicación, los conceptosy la tecnología asociados son muchos y muy heterogéneos. Sin embargo, es imprescindible conocer los aspectos clave de cada uno de estos temas para teneréxito en cualquier proyecto que implique trabajar con bases de datos.En este curso trataremos de dar una visión completa de los conceptos relacionados con los sistemas gestores de bases de datos. En los primeros capítulos veremos los aspectos involucrados en los motores de estos almacenes de datos, suevolución histórica y los distintos tipos de organización y abs-tracción que hanido surgiendo desde su conceptualización hasta nuestros días.A continuación profundizaremos en el modelo llamado relacional (el más usado en nuestros días), proporcionando los métodos y herramientas que nos permitan representar necesidades de almacenamiento y consulta de datos en estemodelo. En el siguiente capítulo estudiaremos a fondo el lenguaje de consultasestructurado SQL, imprescindible para trabajar con bases de datos relacionales,ya sea directamente o a través de cualquier lenguaje de programación.El diseño de bases de datos tiene también un capítulo dedicado a aprender amodelar y representar gráficamente una base de datos, a detectar los posiblesproblemas de diseño antes de que éstos afecten a la aplicación, y a construir bases de datos óptimas para los distintos casos de relaciones entre entidades queformarán nuestra base de datos.Una vez sentadas estas bases, estaremos en disposición de examinar detenidamente dos de los sistemas gestores de bases de datos de software libre más usados y populares actualmente. Así pues, aprenderemos el uso, administración yparticularidades de MySQL y PostgreSQL mediante ejemplos y casos prácticos.También veremos las herramientas de consulta y administración gráficas paraestos dos sistemas gestores de bases de datos, que nos permitirán mejorar nuestra productividad en el trabajo diario con ellos.A continuación, veremos los métodos de acceso a estos sistemas gestores de basesde datos desde algunos lenguajes de programación. En cada caso, comentaremosBases de datos

FUOC 71Z799014MO6las mejores prácticas para cada uno, así como sus particularidades, e introduciremos algunos conceptos relacionados con la programación en bases de datos comola persistencia, tratamiento de errores, etc.Finalmente, creemos que la mejor forma de finalizar este curso es mediante uncaso de estudio completo que aborde los temas tratados en todos los capítulos,en el orden en que se producirían en la realidad de un proyecto y primando lapráctica sobre la teoría.Así pues, este curso trata de proporcionar al estudiante una visión completa delos aspectos implicados en el trabajo con bases de datos. Aunque no profundizaremos en algunos temas muy especializados como el diseño interno de un sistema gestor de bases de datos, profundizaremos técnicamente en los temas másnecesarios.Bases de datos

FUOC 71Z799014MO7ObjetivosLos objetivos que el estudiante deberá alcanzar al finalizar el curso Bases de datosson los siguientes: Comprender los diferentes modelos de bases de datos, y en concreto dominar el modelo relacional. Ser capaz de realizar el modelo de una base de datos relacional, a partir dela especificación de requerimientos de un proyecto, comprendiendo y aplicando los conceptos y transformaciones implicados. Conocer el uso y administración de dos de los gestores de bases de datosrelacionales más populares en el ámbito del software libre: PostgreSQL yMySQL. Tener experiencia en el desarrollo de aplicaciones en conexión con basesde datos en varios lenguajes.Bases de datos

FUOC 71Z799014MO8ContenidosMódulo didáctico 1Introducción a las bases de datosRafael Camps Paré1. Concepto y origen de las BD y de los SGBD2. Evolución de los SGBD3. Objetivos y funcionalidad de los SGBD4. Arquitectura de los SGBD5. Modelos de BD6. Lenguajes y usuarios7. Administración de BDMódulo didáctico 2El modelo relacional y el álgebra relacionalDolors Costal Costa1. Introducción al modelo relacional2. Estructura de los datos3. Operaciones del modelo relacional4. Reglas de integridad5. El álgebra relacionalMódulo didáctico 3El lenguaje SQLCarme Martín Escofet1. Sentencias de definición2. Sentencias de manipulación3. Sentencias de control4. Sublenguajes especializadosMódulo didáctico 4Introducción al diseño de bases de datosDolors Costal Costa1. Introducción al diseño de bases de datos2. Diseño conceptual: el modelo ER3. Diseño lógico: la transformación del modelo ER en el modelo relacionalMódulo didáctico 5Bases de datos en MySQLLuis Alberto Casillas Santillán; Marc Gibert Ginestà; Oscar Pérez Mora1. Características de MySQL2. Acceso a un servidor MySQL3. Creación y manipulación de tablasBases de datos

FUOC 71Z799014MO94. Consultas5. Administración de MySQL6. Clientes gráficosMódulo didáctico 6Bases de datos en PostgreSQLMarc Gibert Ginestà; Oscar Pérez Mora1. Características de PostgreSQL2. Introducción a la orientación a objetos3. Acceso a un servidor PostgreSQL4. Creación y manipulación de tablas5. Manipulación de datos6. Funciones y disparadores7. Administración de PostgreSQL8. Cliente gráfico: pgAdmin3Módulo didáctico 7Desarrollo de aplicaciones en conexión con bases de datosMarc Gibert Ginestà1. Conexión y uso de bases de datos en lenguaje PHP2. Conexión y uso de bases de datos en lenguaje JavaMódulo didáctico 8Caso de estudioMarc Gibert Ginestà1. Presentación del caso de estudio2. El modelo relacional y el álgebra relacional3. El lenguaje SQL4. Introducción al diseño de bases de datos5. Bases de datos en MySQL6. Bases de datos en PostgreSQL7. Desarrollo de aplicaciones en conexión con bases de datosApéndiceGNU Free Documentation LicenseBases de datos

Introduccióna las basesde datosRafael Camps Paré

FUOC 71Z799014MOÍndiceIntroducción. 5Objetivos . 51. Concepto y origen de las BD y de los SGBD . 72. Evolución de los SGBD . 92.1. Los años sesenta y setenta: sistemas centralizados . 92.2. Los años ochenta: SGBD relacionales. 92.3. Los años noventa: distribución, C/S y 4GL. 102.4. Tendencias actuales . 133. Objetivos y servicios de los SGBD . 153.1. Consultas no predefinidas y complejas. 153.2. Flexibilidad e independencia. 153.3. Problemas de la redundancia . 163.4. Integridad de los datos . 183.5. Concurrencia de usuarios . 183.6. Seguridad . 213.7. Otros objetivos. 214. Arquitectura de los SGBD . 224.1. Esquemas y niveles . 224.2. Independencia de los datos . 254.3. Flujo de datos y de control . 275. Modelos de BD . 296. Lenguajes y usuarios. 327. Administración de BD . 35Resumen. 36Actividades. 37Ejercicios de autoevaluación . 37Solucionario. 38Glosario . 38Bibliografía. 39Introducción a las bases de datos

FUOC 71Z799014MO5Introducción a las bases de datosIntroducciónEmpezaremos esta unidad didáctica viendo cuáles son los objetivos de lossistemas de gestión de las bases de datos (SGBD) y, a continuación, daremosuna visión general de la arquitectura, el funcionamiento y el entorno de estossistemas.ObjetivosEn los materiales didácticos de esta unidad encontraréis las herramientas para adquirir una visión global del mundo de las BD y de los SGBD, así como paraalcanzar los siguientes objetivos:1. Conocer a grandes rasgos la evolución de los SGBD desde los años sesentahasta la actualidad.2. Distinguir los principales objetivos de los SGBD actuales y contrastarloscon los sistemas de ficheros tradicionales.3. Saber explicar mediante ejemplos los problemas que intenta resolver elconcepto de transacción.4. Relacionar la idea de flexibilidad en los cambios con la independencia lógica y física de los datos, así como con la arquitectura de tres niveles.5. Distinguir los principales modelos de BD.6. Conocer a grandes rasgos el funcionamiento de un SGBD.7. Saber relacionar los diferentes tipos de lenguajes con los diferentes tipos deusuarios.Introducción a las bases de datos

FUOC 71Z799014MO7Introducción a las bases de datos1. Concepto y origen de las BD y de los SGBDLas aplicaciones informáticas de los años sesenta acostumbraban a darse totalmente por lotes (batch) y estaban pensadas para una tarea muy específica relacionada con muy pocas entidades tipo.Cada aplicación (una o varias cadenas de programas) utilizaba ficheros de movimientos para actualizar (creando una copia nueva) y/o para consultar uno odos ficheros maestros o, excepcionalmente, más de dos. Cada programa trata-Aplicaciones informáticasde los años sesentaLa emisión de facturas, elcontrol de pedidos pendientesde servir, el mantenimientodel fichero de productoso la nómina del personal eranalgunas de las aplicacionesinformáticas habitualesen los años sesenta.ba como máximo un fichero maestro, que solía estar sobre cinta magnética y,en consecuencia, se trabajaba con acceso secuencial. Cada vez que se le queríaañadir una aplicación que requería el uso de algunos de los datos que ya existían y de otros nuevos, se diseñaba un fichero nuevo con todos los datos necesarios (algo que provocaba redundancia) para evitar que los programastuviesen que leer muchos ficheros.A medida que se fueron introduciendo las líneas de comunicación, los terminales y los discos, se fueron escribiendo programas que permitían a variosusuarios consultar los mismos ficheros on-line y de forma simultánea. Más adelante fue surgiendo la necesidad de hacer las actualizaciones también on-line.A medida que se integraban las aplicaciones, se tuvieron que interrelacionarsus ficheros y fue necesario eliminar la redundancia. El nuevo conjunto de ficheros se debía diseñar de modo que estuviesen interrelacionados; al mismotiempo, las informaciones redundantes (como por ejemplo, el nombre y la dirección de los clientes o el nombre y el precio de los productos), que figurabanen los ficheros de más de una de las aplicaciones, debían estar ahora en un sololugar.El acceso on-line y la utilización eficiente de las interrelaciones exigían estructuras físicas que diesen un acceso rápido, como por ejemplo los índices, lasmultilistas, las técnicas de hashing, etc.Estos conjuntos de ficheros interrelacionados, con estructuras complejas ycompartidos por varios procesos de forma simultánea (unos on-line y otros porlotes), recibieron al principio el nombre de Data Banks, y después, a inicios delos años setenta, el de Data Bases. Aquí los denominamos bases de datos (BD).El software de gestión de ficheros era demasiado elemental para dar satisfacción a todas estas necesidades. Por ejemplo, el tratamiento de las interrelacionesno estaba previsto, no era posible que varios usuarios actualizaran datos simultáneamente, etc. La utilización de estos conjuntos de ficheros por parte de losprogramas de aplicación era excesivamente compleja, de modo que, especialmente durante la segunda mitad de los años setenta, fue saliendo al mercadoIntegraciónde aplicacionesPor ejemplo, se integrala aplicación de facturas,la de pedidos pendientesy la gestión del ficherode productos.

FUOC 71Z799014MO8software más sofisticado: los Data Base Management Systems, que aquí denominamos sistemas de gestión de BD (SGBD).Con todo lo que hemos dicho hasta ahora, podríamos definir el términoBD; una base de datos de un SI es la representación integrada de los conjuntos de entidades instancia correspondientes a las diferentes entidadestipo del SI y de sus interrelaciones. Esta representación informática (oconjunto estructurado de datos) debe poder ser utilizada de forma compartida por muchos usuarios de distintos tipos.En otras palabras, una base de datos es un conjunto estructurado de datos querepresenta entidades y sus interrelaciones. La representación será única e integrada, a pesar de que debe permitir utilizaciones varias y simultáneas.Los ficheros tradicionales y las BDAunque de forma muy simplificada, podríamos enumerar las principales diferencias entre losficheros tradicionales y las BD tal y como se indica a continuación:1) Entidades tipos: Ficheros: tienen registros de una sola entidad tipo. BD: tienen datos de varias entidades tipo.2) Interrelaciones: Ficheros: el sistema no interrelaciona ficheros. BD: el sistema tiene previstas herramientas para interrelacionar entidades.3) Redundancia: Ficheros: se crean ficheros a la medida de cada aplicación, con todos los datos necesariosaunque algunos sean redundantes respecto de otros ficheros. BD: todas las aplicaciones trabajan con la misma BD y la integración de los datos es básica,de modo que se evita la redundancia.4) Usuarios Ficheros: sirven para un solo usuario o una sola aplicación. Dan una sola visión del mundoreal. BD: es compartida por muchos usuarios de distintos tipos. Ofrece varias visiones delmundo real.Introducción a las bases de datos

FUOC 71Z799014MO9Introducción a las bases de datos2. Evolución de los SGBDPara entender mejor qué son los SGBD, haremos un repaso de su evolucióndesde los años sesenta hasta nuestros días.2.1. Los años sesenta y setenta: sistemas centralizadosLos SGBD de los años sesenta y setenta (IMS de IBM, IDS de Bull, DMSde Univac, etc.) eran sistemas totalmente centralizados, como corresponde a los sistemas operativos de aquellos años, y al hardware para elque estaban hechos: un gran ordenador para toda la empresa y una redde terminales sin inteligencia ni memoria.Los primeros SGBD –en los años sesenta todavía no se les denominaba así–estaban orientados a facilitar la utilización de grandes conjuntos de datos enlos que las interrelaciones eran complejas. El arquetipo de aplicación era el Billof materials o Parts explosion, típica en las industrias del automóvil, en la construcción de naves espaciales y en campos similares. Estos sistemas trabajabanexclusivamente por lotes (batch).Al aparecer los terminales de teclado, conectados al ordenador central medianteuna línea telefónica, se empiezan a construir grandes aplicaciones on-line transaccionales (OLTP). Los SGBD estaban íntimamente ligados al software de comunicaciones y de gestión de transacciones.Aunque para escribir los programas de aplicación se utilizaban lenguajes dealto nivel como Cobol o PL/I, se disponía también de instrucciones y de subrutinas especializadas para tratar las BD que requerían que el programador conociese muchos detalles del diseño físico, y que hacían que la programación fuesemuy compleja.Puesto que los programas estaban relacionados con el nivel físico, se debíanmodificar continuamente cuando se hacían cambios en el diseño y la organización de la BD. La preocupación básica era maximizar el rendimiento: eltiempo de respuesta y las transacciones por segundo.2.2. Los años ochenta: SGBD relacionalesLos ordenadores minis, en primer lugar, y después los ordenadores micros,extendieron la informática a prácticamente todas las empresas e instituciones.El Data Base / DataComunicationsIBM denominaba Data Base/Data Comunications (DB/DC)el software de comunicacionesy de gestión de transaccionesy de datos. Las aplicacionestípicas eran la reserva/comprade billetes a las compañíasaéreas y de ferrocarriles y,un poco más tarde, las cuentasde clientes en el mundobancario.

FUOC 71Z799014MO10Introducción a las bases de datosEsto exigía que el desarrollo de aplicaciones fuese más sencillo. Los SGBD delos años setenta eran demasiado complejos e inflexibles, y sólo los podía utilizar un personal muy cualificado.La aparición de los SGBD relacionales* supone un avance importantepara facilitar la programación de aplicaciones con BD y para conseguirque los programas sean independientes de los aspectos físicos de la BD.Todos estos factores hacen que se extienda el uso de los SGBD. La estandarización, en el año 1986, del lenguaje SQL produjo una auténtica explosión delos SGBD relacionales.Los ordenadores personalesDurante los años ochenta aparecen y se extienden muy rápidamente los ordenadores personales. También surge software para estos equipos monousuario (por ejemplo, dBase y sus derivados, Access), con los cuales es muy fácil crear y utilizar conjuntos de datos, y que sedenominan personal data bases. Notad que el hecho de denominar SGBD estos primeros sistemas para PC es un poco forzado, ya que no aceptaban estructuras complejas ni interrelaciones, ni podían ser utilizados en una red que sirviese simultáneamente a muchos usuariosde diferentes tipos. Sin embargo, algunos, con el tiempo, se han ido convirtiendo en auténticos SGBD.2.3. Los años noventa: distribución, C/S y 4GLAl acabar la década de los ochenta, los SGBD relacionales ya se utilizaban prácticamente en todas las empresas. A pesar de todo, hasta la mitad de los noventa, cuando se ha necesitado un rendimiento elevado se han seguido utilizandolos SGBD prerrelacionales.A finales de los ochenta y principios de los noventa, las empresas se han encontrado con el hecho de que sus departamentos han ido comprando ordenadores departamentales y personales, y han ido haciendo aplicaciones conBD. El resultado ha sido que en el seno de la empresa hay numerosas BD yvarios SGBD de diferentes tipos o proveedores. Este fenómeno de multiplicación de las BD y de los SGBD se ha visto incrementado por la fiebre de lasfusiones de empresas.La necesidad de tener una visión global de la empresa y de interrelacionar diferentes aplicaciones que utilizan BD diferentes, junto con la facilidad que dan las redes para la intercomunicación entre ordenadores,ha conducido a los SGBD actuales, que permiten que un programa pueda trabajar con diferentes BD como si se tratase de una sola. Es lo quese conoce como base de datos distribuida.Esta distribución ideal se consigue cuando las diferentes BD son soportadaspor una misma marca de SGBD, es decir, cuando hay homogeneidad. Sin em-* Oracle aparece en el año 1980.

FUOC 71Z799014MO11bargo, esto no es tan sencillo si los SGBD son heterogéneos. En la actualidad,gracias principalmente a la estandarización del lenguaje SQL, los SGBD demarcas diferentes pueden darse servicio unos a otros y colaborar para dar servicio a un programa de aplicación. No obstante, en general, en los casos de heterogeneidad no se llega a poder dar en el programa que los utiliza la aparienciade que se trata de una única BD.Figura 1Además de esta distribución “impuesta”, al querer tratar de forma integradadistintas BD preexistentes, también se puede hacer una distribución “deseada”, diseñando una BD distribuida físicamente, y con ciertas partes replicadasen diferentes sistemas. Las razones básicas por las que interesa esta distribución son las siguientes:1) Disponibilidad. La disponibilidad de un sistema con una BD distribuidapuede ser más alta, porque si queda fuera de servicio uno de los sistemas, los de-Introducción a las bases de datos

FUOC 71Z799014MO12Introducción a las bases de datosmás seguirán funcionando. Si los datos residentes en el sistema no disponibleestán replicados en otro sistema, continuarán estando disponibles. En caso contrario, sólo estarán disponibles los datos de los demás sistemas.2) Coste. Una BD distribuida puede reducir el coste. En el caso de un sistemacentralizado, todos los equipos usuarios, que pueden estar distribuidos por distintas y lejanas áreas geográficas, están conectados al sistema central por mediode líneas de comunicación. El coste total de las comunicaciones se puede reducir haciendo que un usuario tenga más cerca los datos que utiliza con mayorfrecuencia; por ejemplo, en un ordenador de su propia oficina o, incluso, en suordenador personal.La tecnología que se utiliza habitualmente para distribuir datos es la quese conoce como entorno (o arquitectura) cliente/servidor (C/S). Todoslos SGBD relacionales del mercado han sido adaptados a este entorno.La idea del C/S es sencilla. Dos procesos diferentes, que se ejecutan enun mismo sistema o en sistemas separados, actúan de forma que unotiene el papel de cliente o peticionario de un servicio, y el otro el de servidor o proveedor del servicio.Por ejemplo, un programa de aplicación que un usuario ejecuta en su PC (queestá conectado a una red) pide ciertos datos de una BD que reside en un equipoUNIX donde, a su vez, se ejecuta el SGBD relacional que la gestiona. El programa de aplicación es el cliente y el SGBD es el servidor.Un proceso cliente puede pedir servicios a varios servidores. Un servidor puederecibir peticiones de muchos clientes. En general, un proceso A que hace decliente, pidiendo un servicio a otro proceso B puede hacer también de servidorde un servicio que le pida otro proceso C (o incluso el B, que en esta peticiónsería el cliente). Incluso el cliente y el servidor pueden residir en un mismo sistema.Figura 2Otros serviciosNotad que el servicio que daun servidor de un sistemaC/S no tiene por qué estarrelacionado con las BD; puedeser un servicio de impresión,de envío de un fax, etc.,pero aquí nos interesan losservidores que son SGBD.

FUOC 71Z799014MO13Introducción a las bases de datosLa facilidad para disponer de distribución de datos no es la única razón, ni siquiera la básica, del gran éxito de los entornos C/S en los años noventa. Talvez el motivo fundamental ha sido la flexibilidad para construir y hacer crecerla configuración informática global de la empresa, así como de hacer modificaciones en ella, mediante hardware y software muy estándar y barato.El éxito de las BD, incluso en sistemas personales, ha llevado a la aparición delos Fourth Generation Languages (4GL), lenguajes muy fáciles y potentes, especializados en el desarrollo de aplicaciones fundamentadas en BD. Proporcionan muchas facilidades en el momento de definir, generalmente de formaC/S, SQL y 4GL. son siglas de moda desde elprincipio de los años noventaen el mundo de los sistemasde información.visual, diálogos para introducir, modificar y consultar datos en entornos C/S.2.4. Tendencias actualesHoy día, los SGBD relacionales están en plena transformación paraadaptarse a tres tecnologías de éxito reciente, fuertemente relacionadas:la multimedia, la de orientación a objetos (OO) e Internet y la web.Los tipos de datos que se pueden definir en los SGBD relacionales de los añosochenta y noventa son muy limitados. La incorporación de tecnologíasmultimedia –imagen y sonido– en los SI hace necesario que los SGBD relacionales acepten atributos de estos tipos.Sin embargo, algunas aplicaciones no tienen suficiente con la incorporación detipos especializados en multimedia. Necesitan tipos complejos que el desarrollador pueda definir a medida de la aplicación. En definitiva, se necesitan tiposabstractos de datos: TAD. Los SGBD más recientes ya incorporaban esta posibilidad, y abren un amplio mercado de TAD predefinidos o librerías de clases.Esto nos lleva a la orientación a objetos (OO). El éxito de la OO al final de losaños ochenta, en el desarrollo de software básico, en las aplicaciones de ingeniería industrial y en la construcción de interfaces gráficas con los usuarios, hahecho que durante la década de los noventa se extendiese en prácticamentetodos los campos de la informática.En los SI se inicia también la adopción, tímida de momento, de la OO. La utilización de lenguajes como C o Java requiere que los SGBD relacionales seadapten a ellos con interfaces adecuadas.La rápida adopción de la web a los SI hace que los SGBD incorporen recursospara ser servidores de páginas web, como por ejemplo

en Software Libre de la UOC. Carme Martín Escofet Oscar Pérez Mora Autora Autor Licenciada en Informática por la Universidad Politécnica de Cataluña. Profesora de la asignatura Introducción a las bases de datos en la Facultad de Informática de Barcelona, y de la asignatura Sistemas orientados a bases de datos en la Facultad de Matemáticas y