mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| test |
| videoclub |
+--------------------+
4 rows in set (0.00 sec)
mysql> use videoclub;
Database changed
mysql> \. peliculas.sql
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 1 row affected, 1 warning (0.00 sec)
Database changed
Query OK, 0 rows affected (0.14 sec)
Query OK, 0 rows affected (0.10 sec)
Query OK, 0 rows affected (0.09 sec)
Query OK, 0 rows affected (0.07 sec)
Query OK, 0 rows affected (0.11 sec)
Query OK, 0 rows affected (0.17 sec)
Query OK, 0 rows affected (0.25 sec)
Query OK, 0 rows affected (0.22 sec)
Query OK, 0 rows affected (0.18 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
mysql> show tables;
+---------------------------------+
| Tables_in_videoclub |
+---------------------------------+
| actor |
| director |
| doc rent |
| ejemplar |
| pelicula |
| pelicula_has_actor |
| socio |
| socio_has_ejemplar |
| socio_has_ejemplar_has_doc rent |
+---------------------------------+
9 rows in set (0.01 sec)
mysql> describe pelicula;
+--------------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------------+-------------+------+-----+---------+-------+
| codigo p | int(11) | NO | PRI | NULL | |
| titulo | varchar(45) | YES | | NULL | |
| nacionalidad | varchar(45) | YES | | NULL | |
| productora | varchar(45) | YES | | NULL | |
| fecha | varchar(45) | YES | | NULL | |
+--------------+-------------+------+-----+---------+-------+
5 rows in set (0.01 sec)
mysql> insert into pelicula values ('12','titanic','inglesa','warner','12-03-90'
);
Query OK, 1 row affected (0.05 sec)
mysql> insert into pelicula values ('13','planetasimios','estadounidense','warne
r','23-05-85');
Query OK, 1 row affected (0.08 sec)
mysql> select codigo p,titulo,nacionalidad,productora,fecha from pelicula;
ERROR 1054 (42S22): Unknown column 'codigo' in 'field list'
mysql> select codigo p , titulo , nacionalidad , productora , fecha from pelicul
a;
ERROR 1054 (42S22): Unknown column 'codigo' in 'field list'
mysql> select titulo , nacionalidad , productora , fecha from pelicula;
+---------------+----------------+------------+----------+
| titulo | nacionalidad | productora | fecha |
+---------------+----------------+------------+----------+
| titanic | inglesa | warner | 12-03-90 |
| planetasimios | estadounidense | warner | 23-05-85 |
+---------------+----------------+------------+----------+
2 rows in set (0.00 sec)
mysql> drop database videoclub;
Query OK, 9 rows affected (0.57 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| test |
+--------------------+
3 rows in set (0.00 sec)
mysql> create database videoclub;
Query OK, 1 row affected (0.00 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| test |
| videoclub |
+--------------------+
4 rows in set (0.00 sec)
mysql> use videoclub;
Database changed
mysql> \. peliculas.sql
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 1 row affected, 1 warning (0.00 sec)
Database changed
Query OK, 0 rows affected (0.13 sec)
Query OK, 0 rows affected (0.09 sec)
Query OK, 0 rows affected (0.09 sec)
Query OK, 0 rows affected (0.10 sec)
Query OK, 0 rows affected (0.10 sec)
Query OK, 0 rows affected (0.11 sec)
Query OK, 0 rows affected (0.13 sec)
Query OK, 0 rows affected (0.14 sec)
Query OK, 0 rows affected (0.14 sec)
Query OK, 0 rows affected (0.14 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
mysql> show tables;
+---------------------------------+
| Tables_in_videoclub |
+---------------------------------+
| actor |
| director |
| doc rent |
| doc rent_has_socio_has_ejemplar |
| ejemplar |
| pelicula |
| pelicula_has_actor |
| pelicula_has_actor1 |
| socio |
| socio_has_ejemplar |
+---------------------------------+
10 rows in set (0.01 sec)
mysql> describe socio;
+-----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+-------------+------+-----+---------+-------+
| dni | int(11) | NO | PRI | NULL | |
| nombre | varchar(45) | YES | | NULL | |
| direccion | varchar(45) | YES | | NULL | |
| telefono | varchar(45) | YES | | NULL | |
| socio_dni | int(11) | NO | MUL | NULL | |
+-----------+-------------+------+-----+---------+-------+
5 rows in set (0.01 sec)
mysql>
miércoles, 23 de noviembre de 2011
miércoles, 26 de octubre de 2011
domingo, 2 de octubre de 2011
1.2 CARACTERISTICAS DEL DBMS
¿QUÉ ES UN SISTEMA MANEJADOR DE BASE DE DATOS(DBMS)?
Un sistema de gestión de bases de datos (SGBD; en inglés, Database Management System: DBMS) es un conjunto de programas que permite a los usuarios crear y mantener una base de datos.
Si bien, no es imprescindible contar con un SGBD para implementar una base de datos, este software de uso general facilita el proceso de definir, construir y manipular bases de datos para diversas aplicaciones.
CARACTERISTICAS DE LOS DBMS
· Restricción de los accesos no autorizados
· Cumplimiento de las restricciones de integridad
· Respaldo y recuperación
TIPOS DE DBMS
Existen cinco modelos de DBMS, que se distinguen según cómo representan los datos almacenados:
· El modelo jerárquico: los datos se organizan jerárquicamente mediante un árbol invertido. Este modelo utiliza punteros para navegar por los datos almacenados. Fue el primer modelo DBMS.
· El modelo de red: al igual que el modelo jerárquico, este modelo utiliza punteros hacia los datos almacenados. Sin embargo, no necesariamente utiliza una estructura de árbol invertido.
· El modelo relacional (RDBMS, Relational database management system [Sistema de administración de bases de datos relacionales]): los datos se almacenan en tablas de dos dimensiones (filas y columnas). Los datos se manipulan según la teoría relacional de matemáticas.
· El modelo deductivo: los datos se representan como una tabla, pero se manipulan mediante cálculos de predicados.
· El modelo de orientación a objetos (ODBMS, object-oriented database management system [sistema de administración de bases de datos orientadas a objetos]): los datos se almacenan como objetos, que son estructuras denominadas clases que muestran los datos que contienen. Los campos son instancias de estas clases.
DIFERENTES DBMS
DBMS libres
• PostgreSQL
• MySQL7.7.
DBMS comerciales
• Oracle
• DB2, Informix (IBM)
• dBase (dBI)
• Paradox (Borland)
• SQL-Server (MS)
• Access (MS)
• FoxPro (MS)
Todos los conceptos referentes a las bases de datos están hoy muy claros y definidos formalmente, al contrario que los de las bases de conocimiento. La tecnología de gestión de bases de datos se halla en una etapa muy madura. Las bases de datos han evolucionado durante los pasados 30 años desde sistemas de archivos rudimentarios hasta sistemas gestores de complejas estructuras de datos que ofrecen un gran número de posibilidades. Los principales objetivos de un DBMS son los siguientes:
- Independencia lógica y física de los datos: se refiere a la capacidad de modificar una definición de esquema en un nivel de la arquitectura sin que esta modificación afecte al nivel inmediatamente superior. Para ello un registro externo en un esquema externo no tiene por qué ser igual a su registro correspondiente en el esquema conceptual.6
- Redundancia mínima: se trata de usar la base de datos como repositorio común de datos para distintas aplicaciones.
- Acceso concurrente por parte de múltiples usuarios: control de concurrencia mediante técnicas de bloqueo o cerrado de datos accedidos.
- Distribución espacial de los datos: la independencia lógica y física facilita la posibilidad de sistemas de bases de datos distribuidas. Los datos pueden encontrarse en otra habitación, otro edificio e incluso otro país. El usuario no tiene por qué preocuparse de la localización espacial de los datos a los que accede.
- Integridad de los datos: se refiere a las medidas de seguridad que impiden que se introduzcan datos erróneos. Esto puede suceder tanto por motivos físicos (defectos de hardware, actualización incompleta debido a causas externas), como de operación (introducción de datos incoherentes).
- Consultas complejas optimizadas: la optimización de consultas permite la rápida ejecución de las mismas.
- Seguridad de acceso y auditoría: se refiere al derecho de acceso a los datos contenidos en la base de datos por parte de personas y organismos. El sistema de auditoría mantiene el control de acceso a la base de datos, con el objeto de saber qué o quién realizó una determinada modificación y en qué momento.
- Respaldo y recuperación: se refiere a la capacidad de un sistema de base de datos de recuperar su estado en un momento previo a la pérdida de datos.
- Acceso a través de lenguajes de programación estándar: se refiere a la posibilidad ya mencionada de acceder a los datos de una base de datos mediante lenguajes de programación ajenos al sistema de base de datos propiamente dicho.
Una base de datos típica conlleva la existencia de tres tipos de usuario con relación a su diseño, desarrollo y uso:
- El administrador de bases de datos (DBA: Database Administrator): diseña y mantiene la DB.
- El desarrollador de aplicaciones (programador): implementa las transacciones e interfaces.
- Los usuarios finales: consultan y editan los datos de la DB mediante un lenguaje de consulta de alto nivel.
INTRODUCCIÓN A LOS SISTEMAS DE BASES DE DATOS
Un sistema de base de datos es algo más que simples datos o que un conjunto de datos en combinación con unos programas de gestión. Un sistema de base de datos está formado por los siguientes componentes:
DATOS
Las características más importantes de la información en estos sistemas es que va a estar integrada y compartida
Integrada: se considera como una unificación de varios ficheros de datos, que son tratados como uno solo, y en el que se ha eliminado totalmente, o en parte, la redundancia de datos.
Compartida: Los datos pueden compartirse entre varios usuarios distintos.
EQUIPO (HARDWARE )
Conjunto de dispositivos físicos utilizados para almacenar y procesar los datos.
Ordenadores :utilizados para procesar los datos de la Base de datos: pueden ser mainframe*, miniordenador u ordenador personal. El mainframe y los miniordenadores fueron utilizados tradicionalmente para soportar el acceso de varios usuarios a una base de datos común. Los ordenadores personales eran empleados, inicialmente, para manejar bases de datos autónomas controladas y manipuladas por un usuario único. No obstante, actualmente, también pueden conectarse a una red cliente/servidor, garantizando el acceso de varios usuarios a una base de datos común almacenada en unidades de disco y controladas por un ordenador servidor. El servidor puede ser otro ordenador personal más potente, o bien, un miniordenador o un mainframe.
VOLÚMENES DE ALMACENAMIENTO:
Generalmente son unidades de disco que constituyen el mecanismo de almacenamiento principal para las bases de datos.
Otros dispositivos: como unidades de cinta, terminales, impresoras, etc.
ADMINISTRADOR DE LA BASE DE DATOS (A.B.D.).
Son los encargados de diseñar la estructura de la base de datos y los responsables de que el sistema funcione correctamente. El A.B.D. se encarga de autorizar el acceso a la base de datos, de coordinar y vigilar su utilización y de adquirir los recursos necesarios de software y hardware. El A.B.D. es el responsable cuando surgen problemas como violaciones de seguridad o una respuesta lenta del sistema. El A.B.D.
PROGRAMADORES DE APLICACIONES
Se encargan de desarrollar las aplicaciones que manejan datos de la base de datos. Estas aplicaciones contendrán solicitudes de datos al S.G.B.D que luego serán procesados por los programas de la aplicación que tendrán como finalidad resolver problemas específicos de la empresa.
USUARIOS FINALES
Son personas que no tienen por que tener conocimientos informáticos y que pueden manipular los datos (examinarlos y actualizarlos) con la ayuda de las aplicaciones, o bien de lenguajes de consulta no procedimentales (no es necesario indicar el algoritmo de acceso a los datos), tipo SQL, o bien, mediante herramientas basadas en sistemas de menús. Se distinguen tres tripos de usuarios finales:
· Usuarios especializados
· Usuarios casuales
· Usuarios ingenuos
TEMA 2: DDL
LA EXPOSICION DEL EQUIPO
2. LENGUAJE DE DEFINICIÓN DE DATOS (DDL)
Una base de datos en un sistema relacional está compuesta por un conjunto de tablas, que corresponden a las relaciones del modelo relacional. En la terminología usada en SQL no se alude a las relaciones, del mismo modo que no se usa el término atributo, pero sí la palabra columna, y no se habla de tupla, sino de línea.
2.1 creación de base de datos
A nivel teórico, existen dos lenguajes para el manejo de bases de datos:
DDL (Data Definition Language) Lenguaje de definición de datos. Es el lenguaje que se usa para crear bases de datos y tablas, y para modificar sus estructuras, así como los permisos y privilegios.
Este lenguaje trabaja sobre unas tablas especiales llamadas diccionario de datos.
DML (Data Manipilation Language) lenguaje de manipulación de datos. Es el que se usa para modificar y obtener datos desde las bases de datos.
Crear una base de datos
Cada conjunto de relaciones que componen un modelo completo forma una base de datos. Desde el punto de vista de SQL, una base de datos es sólo un conjunto de relaciones (o tablas), y para organizarlas o distinguirlas se accede a ellas mediante su nombre. A nivel de sistema operativo, cada base de datos se guarda en un directorio diferente.
Debido a esto, crear una base de datos es una tarea muy simple. Claro que, en el momento de crearla, la base de datos estará vacía, es decir, no contendrá ninguna tabla.
Creación de tablas
El mandato para la creación de tablas o esquemas relacionales es CREATE TABLE. Básicamente se debe definir los atributos que componen la tabla, la clave primaria, las posibles claves ajenas y las restricciones a imponer sobre los valores de los atributos. Cada definición se separa de la siguiente con una coma. La sintaxis general es la siguiente:
CREATE TABLE nombre_tabla(
definición de atributo 1,
.....................
definición de atributo a,
definición de clave primaria,
definición de clave foránea 1,
.....................
definición de clave foránea f,
definición de restricción 1,
definición de restricción r);
Definición de atributos
El tipo de datos del atributo especifica sus posibles valores válidos. Los tipos de datos más habituales son NUMBER (número entero), DATE (fecha), CHAR (cadena de caracteres de longitud fija) y VARCHAR2 (cadena de caracteres de longitud máxima fija y longitud real variable).
COMPLEMENTO DE LA INFORMACION
El lenguaje de Definición de datos, en inglés Data Definition Language (DLL), es el que se encarga de la modificación de la estructura de los objetos de la base de datos. Existen cuatro operaciones básicas: CREATE, ALTER, DROP y TRUNCATE.
CREATE
Este comando crea un objeto dentro de la base de datos. Puede ser una tabla, vista, índice, trigger, función, procedimiento o cualquier otro objeto que el motor de la base de datos soporte.
Ejemplo 1 (creación de una tabla):
CREATE TABLE TABLA_NOMBRE (
cl integer not null
nombre VARCHAR (50)
fecha_nac DATE NOT NULL,
PRIMARY KEY (my_field1, my_field 2)
CREATE
Este comando crea un objeto dentro de la base de datos. Puede ser una tabla, vista, índice, trigger, función, procedimiento o cualquier otro objeto que el motor de la base de datos soporte.
Ejemplo 1 (creación de una tabla):
CREATE TABLE TABLA_NOMBRE (
cl integer not null
nombre VARCHAR (50)
fecha_nac DATE NOT NULL,
PRIMARY KEY (my_field1, my_field 2)
ALTER
Este comando permite modificar la estructura de un objeto- Se pueden agregar / quitar campos a una tabla, modificar el tipo de un campo, agregar / quitar índices a una tabla, modificar un trigger, etc.
Ejemplo 1 (agregar columna a una tabla):
ALTER TABLE TABLA NOMBRE (
ADD NUEVO_ CAMPO INT UNSIGNED
)
DROP
Este comando elimina un objeto de la base de datos. Puede ser una tabla, vista, índice, trigger, función, procedimiento o cualquier otro objeto que el motor de la base de datos soporte. Se puede combinar con la sentencia ALTER.
Ejemplo 1:
DROP TABLE TABLA_NOMBRE
Ejemplo 2:
ALTER TABLE TABLA_NOMBRE
(DROP COLUMN CAMPO_NOMBRE 1)
ALTER TABLE TABLA_NOMBRE
(DROP COLUMN CAMPO_NOMBRE 1)
TRUNCATE
Este comando trunca todo el contenido de una tabla. La ventaja sobre el comando DELETE, es que si se quiere borrar todo el contenido de la tabla, es mucho más rápido, especialmente si la tabla es muy grande, la desventaja es que TRUNCATE solo sirve cuando se quiere eliminar absolutamente todos los registros, ya que no se permite la cláusula WHERE. Si bien, en un principio, esta sentencia parecería ser DML (Lenguaje de Manipulación de Datos), es en realidad una DDL, ya que internamente, el comando truncate borra la tabla y la vuelve a crear y no ejecuta ninguna transacción.
Ejemplo 1:
TRUNCATE TABLE TABLA_NOMBRE
Suscribirse a:
Entradas (Atom)