E N D
Definición de Base de Datos • Una base de datos o banco de datos es un conjunto de datos que pertenecen al mismo contexto almacenados sistemáticamente para su posterior uso. Una Base de Datos es un repositorio centralizado, compuesto por datos que pueden ser usados simultáneamente por múltiples usuarios.
Definición de base de datos • En informática existen los sistemas gestores de bases de datos (SGBD), es el software que interactúa con los programas de aplicación del usuario y con la base de datos.
SGBD proporciona la siguiente funcionalidad • Permite a los usuarios definir la base de datos, usualmente sobre un lenguaje de definición de datos (DLL Data DefinitionLanguage). El DLL permite a los usuarios especificar las estructuras y tipos de datos y las restricciones aplicables a los datos que hay que almacenar en la base de datos.
SGBD proporciona la siguiente SGBD proporciona la siguiente funcionalidad • Permite a los usuarios insertar, actualizar, borrar y extraer datos de la base de datos, usualmente mediante un lenguaje de manipulación de datos (DML Data ManipulationLanguage). Al disponer de un repositorio centralizado para todos los datos y las descripciones de los datos, el lenguaje DML puede proporcionar un lenguaje de consulta de esos datos. El lenguaje de consulta mas común es el lenguaje SQL (StructuredQueryLanguage, lenguaje estructurado de consulta), que ahora es tanto el standard formal como el standard de facto par los SGBD relacionales.
Acceso controlado a la base de datos, puede proporcionar: • Un sistema de seguridad: evita que los usuarios no autorizados accedan • Un sistema de integridad: mantiene la coherencia de los datos almacenados • Un sistema de control de concurrencia: permite el acceso compartido a la base de datos • Un sistema de control de recuperación: restaura la base de datos a un estado previo coherente, después de cada fallo de hardware o software.
Componentes de un entorno de SGBD • Hardware: • El SGBD y las aplicaciones requieren una plataforma de hardware para ejecutarse. Este puede ser desde una computadora personal hasta un mainframe o una red de computadoras. El hardware depende de las necesidades de la organización y del SGBD utilizado.
Componentes de un entorno de SGBD • Software: • El componente software comprende el propio software de SGBD y los programas de aplicación, junto con el sistema operativo. Los programas de aplicación se escriben en lenguajes de aplicación de tercera generación (3GL), como C, C++, Java, Visual Basic, .net,etc. O lenguaje de cuarta generación (4GL) como SQL incrustado dentro de un lenguaje 3GL
Componentes de un entorno de SGBD • Datos: • Quizás el componente mas importante de un entorno de SGBD, al menos desde el punto de vista de los usuarios finales.
Componentes de un entorno de SGBD • Procedimientos: • Los procedimientos son las instrucciones y reglas que gobiernan el diseño y utilización de la base de datos. Los usuarios del sistema y el personal que gestiona la base de datos requiere una serie de procedimientos documentados que les permita saber como utilizar o ejecutar el sistema
Componentes de un entorno de SGBD Por ejemplo • Iniciar una sesión en el SGBD • Utilizar una funcionalidad concreta • Iniciar y detener el SGBD • Realizar copias de seguridad de la base de datos • Gestionar los fallos de hardware o de software • Cambiar la estructura de una tabla, reorganizar la base de datos, mejorar el rendimiento, etc
Componentes de un entorno de SGBD • Personas: • El componente final son las personas que se relacionan con el sistema.
Tipos de bases de datos • Bases de datos estáticas • Bases de datos dinámicas • Bases de datos bibliográficas • Bases de datos de texto completo • Directorios • Banco de imágenes, audio, video, multimedia, etc
Bases de datos estáticas • Éstas son bases de datos de sólo lectura, utilizadas primordialmente para almacenar datos históricos que posteriormente se pueden utilizar para estudiar el comportamiento de un conjunto de datos a través del tiempo, realizar proyecciones y tomar decisiones.
Bases de datos dinámicas • Éstas son bases de datos donde la información almacenada se modifica con el tiempo, permitiendo operaciones como actualización y adición de datos, además de las operaciones fundamentales de consulta. Un ejemplo de esto puede ser la base de datos utilizada en un sistema de información de un comercio, una farmacia, un videoclub, etc.
Bases de datos bibliográficas • Solo contienen un surrogante (representante) de la fuente primaria, que permite localizarla. Un registro típico de una base de datos bibliográfica contiene información sobre el autor, fecha de publicación, editorial, título, edición, de una determinada publicación, etc.
Bases de datos de texto completo • Almacenan las fuentes primarias, como por ejemplo, todo el contenido de todas las ediciones de una colección de revistas científicas.
Directorios • Un ejemplo son las guías telefónicas en formato electrónico.
Banco de imágenes, audio, video, multimedia, etc • Son bases de datos que almacenan diferentes tipos de información proveniente de las ciencias de la vida o médicas. Se pueden considerar en varios subtipos:
Modelos de bases de datos • Además de la clasificación por la función de las bases de datos, éstas también se pueden clasificar de acuerdo a su modelo de administración de datos. • Un modelo de datos es básicamente una "descripción" de algo conocido como contenedor de datos (algo en donde se guarda la información), así como de los métodos para almacenar y recuperar información de esos contenedores. Los modelos de datos no son cosas físicas: son abstracciones que permiten la implementación de un sistema eficiente de base de datos; por lo general se refieren a algoritmos, y conceptos matemáticos.
Modelos de bases de datos • Bases de datos jerárquica • Base de datos de red • Base de datos relacional • Bases de datos orientadas a objetos • Bases de datos documentales • Base de datos deductivas • Gestión de bases de datos distribuida
Bases de datos jerárquica • Éstas son bases de datos que, como su nombre indica, almacenan su información en una estructura jerárquica. En este modelo los datos se organizan en una forma similar a un árbol (visto al revés), en donde un nodo padre de información puede tener varios hijos. El nodo que no tiene padres es llamado raíz, y a los nodos que no tienen hijos se los conoce como hojas. • Las bases de datos jerárquicas son especialmente útiles en el caso de aplicaciones que manejan un gran volumen de información y datos muy compartidos permitiendo crear estructuras estables y de gran rendimiento. • Una de las principales limitaciones de este modelo es su incapacidad de representar eficientemente la redundancia de datos.
Base de datos de red • Éste es un modelo ligeramente distinto del jerárquico; su diferencia fundamental es la modificación del concepto de nodo: se permite que un mismo nodo tenga varios padres (posibilidad no permitida en el modelo jerárquico). • Fue una gran mejora con respecto al modelo jerárquico, ya que ofrecía una solución eficiente al problema de redundancia de datos; pero, aun así, la dificultad que significa administrar la información en una base de datos de red ha significado que sea un modelo utilizado en su mayoría por programadores más que por usuarios finales.
Base de datos relacional • Éste es el modelo más utilizado en la actualidad para modelar problemas reales y administrar datos dinámicamente. • En este modelo, el lugar y la forma en que se almacenen los datos no tienen relevancia (a diferencia de otros modelos como el jerárquico y el de red). Esto tiene la considerable ventaja de que es más fácil de entender y de utilizar para un usuario esporádico de la base de datos. La información puede ser recuperada o almacenada mediante "consultas" que ofrecen una amplia flexibilidad y poder para administrar la información. • El lenguaje más habitual para construir las consultas a bases de datos relacionales es SQL, StructuredQueryLanguage o Lenguaje Estructurado de Consultas, un estándar implementado por los principales motores o sistemas de gestión de bases de datos relacionales.
Bases de datos orientadas a objetos • Este modelo, bastante reciente, y propio de los modelos informáticos orientados a objetos, trata de almacenar en la base de datos los objetos completos (estado y comportamiento). • Una base de datos orientada a objetos es una base de datos que incorpora todos los conceptos importantes del paradigma de objetos.
Bases de datos documentales • Permiten la indexación a texto completo, y en líneas generales realizar búsquedas más potentes. Tesaurus es un sistema de índices optimizado para este tipo de bases de datos.
Base de datos deductivas • Un sistema de base de datos deductivas, es un sistema de base de datos pero con la diferencia de que permite hacer deducciones a través de inferencias. Se basa principalmente en reglas y hechos que son almacenados en la base de datos. También las bases de datos deductivas son llamadas base de datos lógica, a raíz de que se basan en lógica matemática.
Gestión de bases de datos distribuida • La base de datos está almacenada en varias computadoras conectadas en red. Surgen debido a la existencia física de organismos descentralizados. Esto les da la capacidad de unir las bases de datos de cada localidad y acceder así a distintas universidades, sucursales de tiendas, etcétera
SGBD libres • PostgreSQL • MySQL • Firebird • SQLite • DB2
SGBD gratuitos • Microsoft SQL Server Compact Edition • Sybase ASE (Edición gratuita para Linux) • ORACLE Express
SGBD comerciales • dBase • Fox Pro • IBMDB2 • IBMInformix • MAGIC • Microsoft Access • Microsoft SQL Server • Oracle • Sybase