Taller de Base de Datos Tema 2.1
Taller de Base de Datos Tema 2.1
Taller de Base de Datos Tema 2.1
DE DATOS
TECNOLGICO DE ESTUDIOS SUPERIORES DE VALLE DE BRAVO
UNIDAD 2 Tarea 1
Quinto semestre
POR:
Esmelin Magdiel Garca Coln
TALLER DE BASES
DE DATOS
NDICE.
Objetivo General.
Objetivos Especficos.
Introduccin.
Desarrollo 1.
Conclusiones.
15
NDICE DE FIGURAS.
Figura 1 Estructura.
Figura 2 Consulta 1.
Figura 3 Consulta 2.
TALLER DE BASES
DE DATOS
Objetivo general
Desarrollar la base de datos Matrimonios en Oracle.
Objetivos especficos
1. Identificar las restricciones.
2. Realizar las tablas propuestas.
3. Realizar la estructura y diseo de las relaciones.
TALLER DE BASES
DE DATOS
Introduccin
Con el ejercicio propuesto Matrimonios, realizar la base de datos
correspondiente respetando las restricciones y cumpliendo con las necesidades
propuestas.
TALLER DE BASES
DE DATOS
Desarrollo
2.1 Insercin, eliminacin y modificacin de registros
La sentencia INSERT permite agregar nuevas filas de datos a las tablas
existentes. Est sentencia tiene como sintaxis genrica.
INSERT
INTO
tabla_o_vista
[(lista_de_columnas)]
VALUES
(lista_de_valores_de_datos)
Para insertar datos en una relacin, se especfica la tupla que se desea insertar o
se formula una consulta cuyo resultado sea el conjunto de tuplas que se desea
insertar. Obviamente, los valores de los atributos de las tuplas que se inserten
deben pertenecer al dominio de los atributos. De igual modo, las tuplas insertadas
deben ser de la aridad -nmero de atributos- correcta.
Borrar todas las filas que cumplan la condicin especificada en la clusula
WHERE. Si esta clusula se omite, se borrarn todas las filas de la tabla. DELETE
borra todas las filas de una tabla, pero no la definicin de la tabla del diccionario.
Esta es una diferencia con la sentencia DROPTABLE, que elimina el contenido de
la tabla y la definicin de la misma.
La sintaxis es la que sigue:
DELETE FROM tabla [WHERE condicin];
Obsrvese que cada comando DELETE slo opera sobre una relacin. Si se
desea borrar tuplas de varias relaciones es necesario utilizar una orden DELETE
por cada relacin.
La consulta
DELETE FROM empleados;
TALLER DE BASES
DE DATOS
Borra todas las tuplas de la tabla empleados
La consulta
DELETE FROM empleados WHERE cargo = 'Chofer';
Borra los empleados con cargo de chofer
Cuando trabajemos con la sentencia DELETE debemos tener en cuenta las
siguientes consideraciones:
Solo podemos borrar datos de una nica tabla.
Cuando borramos datos de una vista, los estamos borrando tambin de la
tabla. Las vistas son solo una forma de ver los datos, no una copia.
Si intentamos borrar un registro de una tabla referenciada por una FOREING
KEY como tabla maestra, si la tabla dependiente tiene registros relacionados la
sentencia DELETE fallar a no ser que la tabla hija contenga la sentencia ON
DELETE CASCADE.
Considere el siguiente Diagrama Entidad Relacin y su correspondiente script
Oracle
En determinadas situaciones puede ser deseable cambiar un valor dentro de una
tupla, sin cambiar todos los valores de la misma. Para ello se utiliza el comando
UPDATE cuya sintaxis se muestra a continuacin.
UPDATE tabla SET {columna = expresin,} + [WHERE condicin;]
Se especificar en la clusula SET las columnas que se actualizarn y con qu
valores. La clusula WHERE indica las filas con las que se va a trabajar, sin la
clusula WHERE la actualizacin afectar a todas las filas de la tabla.
Si se desea actualizar a nulos, se asignar el valor NULL.
TALLER DE BASES
DE DATOS
TALLER DE BASES
DE DATOS
se quiere recuperar. Esta es la sentencia SQL, ms habitual. La sentencia
SELECT consta de cuatro partes bsicas:
La clusula SELECT seguida de la descripcin de lo que se desea ver, los
nombres de las columnas a seleccionar. Esta parte es obligatoria.
La clusula FROM seguida de la especificacin de las tablas de las que se han
de obtener los datos. Esta parte es obligatoria.
La clusula WHERE seguida por un criterio de seleccin, una condicin. Esta
parte es opcional.
La clusula ORDER BY seguida por el criterio de ordenacin. Esta parte es
opcional.
Una primera aproximacin a la sintaxis de la sentencia SELECT puede mostrarnos
la siguiente expresin:
SELECT {* | {columna,}+} FROM {tabla,}+ [WHERE condicin] [ORDER BY
{expresinColumna [ASC | DESC],}+];
Seleccin de columnas
Las columnas a seleccionar se enumeran sin ms en la clusula SELECT. Para
seleccionar todas las columnas use el carcter asterisco ' *'.
Cuando se consulta una base de datos, los nombres de las columnas se usan
como cabeceras de presentacin. Si ste resulta demasiado largo, corto o crptico,
puede cambiarse con la misma sentencia SQL de consulta, creando un alias de
columna.
TALLER DE BASES
DE DATOS
TALLER DE BASES
DE DATOS
Figura 1 Estructura.
En la clusula GROUP BY se colocan las columnas por las que vamos a agrupar.
Y en la clusula HAVING filtra los registros una vez agrupados.
columnas
de
tablas
diferentes,
entonces
deberemos
utilizar
TALLER DE BASES
DE DATOS
As, podramos intentar una consulta que seleccionara el campo nombre de la
tabla empleado y el nombre del departamento. Y aqu surge el primer problema,
cmo distinguimos entre dos columnas que, llamndose igual, pertenecen a
tablas distintas?
El uso de alias para las tablas incluidas en el FROM o en las columnas del
SELECT permite evitar la ambigedad, el alias se separa por un espacio.
3.2.5 Sub-consultas
Una sub-consulta es una instruccin SELECT anidada dentro de una sentencia
SELECT, SELECT...INTO, INSERT...INTO, DELETE, o UPDATE o dentro de otra
sub-consulta.
Una sub-consulta, a su vez, puede contener otra sub-consulta y as hasta un
mximo de 16 niveles. Las particularidades de las sub-consultas son:
1. Su resultado no se visualiza, sino que se pasa a la consulta principal para su
comprobacin.
2. Puede devolver un valor nico o una lista de valores y en dependencia de esto
se debe usar el operador del tipo correspondiente.
3. No puede usar el operador BETWEEN, ni contener la sentencia ORDER BY.
4. Puede contener una sola columna, que es lo ms comn, o varias columnas.
Este ltimo caso se llama sub-consulta con columnas mltiples. Cuando dos o
ms columnas sern comprobadas al mismo tiempo, deben encerrarse entre
parntesis.
Ejemplo: Nombres de los jugadores que han participado ms que el promedio,
equipo y posicin durante un torneo
11
TALLER DE BASES
DE DATOS
Figura 2 consulta
12
TALLER DE BASES
DE DATOS
Ejemplo: Jugadores que participaron con el Cruz Azul durante el torneo Apertura
2011, minutos jugados y partidos en los que participo (JJ)
Figura 3 Consulta 2
13
TALLER DE BASES
DE DATOS
Conclusin
Las estructuras descritas anteriormente fueron ideadas de tal forma que nos
permitieran facilitar la interaccin del desarrollador con la base de datos.
14