Академический Документы
Профессиональный Документы
Культура Документы
Vamos a aplicar buena parte de lo que conocemos para hacer un ejercicio de repaso que haga distintas manipulaciones a una nica tabla. Ser una tabla que contenga datos de productos: cdigo, nombre, precio y fecha de alta, para que podamos trabajar con datos de texto, numricos y de tipo fecha. PRODUCTOS(Codigo, nombre, precio, fechaAlta) Los pasos que realizaremos (por si alguien se atreve a intentarlo antes de ver la solucin) sern:
Crear la base de datos Comenzar a usarla Introducir 3 datos de ejemplo Consultas en SQL: 1. Mostrar todos los datos 2. Mostrar los datos que tienen un cierto nombre 3. Mostrar los datos que comienzan por una cierta inicial 4. Ver slo el nombre y el precio de los que cumplen una condicin (precio > 22) 5. Ver el precio medio de aquellos cuyo nombre comienza con "Silla" 6. Modificar la estructura de la tabla para aadir un nuevo campo: "categora" 7. Dar el valor "utensilio" a la categora de todos los productos existentes 8. Modificar los productos que comienza por la palabra "Silla", para que su categora sea "silla" 9. Ver la lista categoras (sin que aparezcan datos duplicados) 10. Ver la cantidad de productos que tenemos en cada categora
Damos por sentado que MySQL est instalado. El primer paso es crear la base de datos:
create database productos1;
Y comenzar a usarla:
use productos1;
1.
Podemos ver todos los datos para comprobar que son correctos:
y deberamos obtener
+--------+----------------+--------+------------+ | codigo | nombre | precio | fechaalta | +--------+----------------+--------+------------+ | a01 | Afilador | 2.50 | 2007-11-02 | | s01 | Silla mod. ZAZ | 20.00 | 2007-11-03 | | s02 | Silla mod. XAX | 25.00 | 2007-11-03 | +--------+----------------+--------+------------+ 2.
select * from productos where nombre='Afilador'; +--------+----------+--------+------------+ | codigo | nombre | precio | fechaalta | +--------+----------+--------+------------+ | a01 | Afilador | 2.50 | 2007-11-02 | +--------+----------+--------+------------+ 3.
select * from productos where nombre like 'S%'; +--------+----------------+--------+------------+ | codigo | nombre | precio | fechaalta | +--------+----------------+--------+------------+ | s01 | Silla mod. ZAZ | 20.00 | 2007-11-03 | | s02 | Silla mod. XAX | 25.00 | 2007-11-03 | +--------+----------------+--------+------------+ 4.
Si queremos ver cuales tienen un precio superior a 22, y adems no deseamos ver todos los campos, sino slo el nobre y el precio:
select nombre, precio from productos where precio > 22; +----------------+--------+ | nombre | precio | +----------------+--------+ | Silla mod. XAX | 25.00 |
+----------------+--------+ 5.
select avg(precio) from productos where left(nombre,5) = 'Silla'; +-------------+ | avg(precio) | +-------------+ | 22.500000 | +-------------+ 6.
Esto de mirar las primeras letras para saber si es una silla o no... quiz no sea la mejor opcin. Parece ms razonable aadir un nuevo dato: la "categora". Vamos a modificar la estructura de la tabla para hacerlo:
Ahora mismo, todas las categoras tienen el valor NULL, y eso no el muy til. Vamos a dar el valor "utensilio" a la categora de todos los productos existentes
8.
Y ya que estamos, modificaremos los productos que comienza por la palabra "Silla", para que su categora sea "silla"
update productos set categoria="silla" where left(nombre,5) = 'Silla'; +--------+----------------+--------+------------+-----------+ | codigo | nombre | precio | fechaalta | categoria | +--------+----------------+--------+------------+-----------+ | a01 | Afilador | 2.50 | 2007-11-02 | utensilio | | s01 | Silla mod. ZAZ | 20.00 | 2007-11-03 | silla | | s02 | Silla mod. XAX | 25.00 | 2007-11-03 | silla | +--------+----------------+--------+------------+-----------+ 9.
Para ver la lista categoras (sin que aparezcan datos duplicados), deberemos usar la palabra "distinct"
Finalmente, para ver la cantidad de productos que tenemos en cada categora, deberemos usar "count" y agrupar los datos con "group by", as:
select categoria, count(*) from productos group by categoria; +-----------+----------+ | categoria | count(*) | +-----------+----------+ | silla | 2 | | utensilio | 1 | +-----------+----------+
2- Introducir los datos: (CON INSTRUCCIONES SQL) En equipos: - rcm, Real Campello, baloncesto - can, Canoa, natacion - ssj, Sporting de San Juan, futbol
INSERT INTO deportes.equipo ( Codigo , Nombre , Deporte) VALUES ('rcm', 'Real Campello', 'Baloncesto'), ('can', 'Canoa', 'natacion'), ('ssj', 'Sporting de San Juan', 'Futbol');
En jugadores: - rml, Ral, Martnez, Lpez, pivot (juega en el Real Campello) - rl, Ral, Lpez, , saltador (del Canoa)
- jl, Jordi, Lpez, , nadador crawl(del Canoa) - rol, Roberto, Linares, , base (juega en el Real Campello)
INSERT INTO deportes.jugador( codigo , nombre , Apellido1 , Apellido2 , Demarcacion , Codequipo )VALUES ('rml', 'Raul', 'Martinez', 'Lopez', 'Pivot', 'rcm'), ('rl', 'Raul', 'Lopez', '', 'saltador', 'can'), ('jl', 'Jordi', 'Lopez', '', 'nadador crawl', 'can'), ('rol', 'Roberto', 'Linares', '', 'Base', 'rcm');
3- Crear una consulta que muestre: nombre de deportista, primer apellido, demarcacin, nombre de equipo (para todos los jugadores de la base de datos).
SELECT jugador.nombre, apellido1, apellido2, demarcacion, equipo.nombre FROM jugador, equipo WHERE jugador.codequipo = equipo.codigo
4- Crear una consulta que muestre el nombre de los equipos para los que no sabemos los jugadores.
SELECT nombre FROM equipo WHERE codigo NOT IN ( SELECT codequipo FROM jugador)
5- Crear una consulta que muestre nombre y apellidos de los jugadores cuyo primer o segundo apellido es "Lpez".
SELECT nombre, apellido1, apellido2 FROM jugador WHERE apellido1 = "lopez" OR apellido2 = "lopez"
7- Crear una consulta que muestre la cantidad de jugadores que hay en cada equipo.
SELECT count( * ) , codequipo FROM jugador
GROUP BY codequipo
8- Crear una consulta que muestre la cantidad de jugadores que hay en cada deporte.
SELECT equipo.nombre, count( jugador.codigo ) FROM jugador, equipo WHERE equipo.codigo = jugador.codequipo GROUP BY equipo.nombre
10- Aadir a la tabla de jugadores un campo en el que poder almacenar la antigedad (en aos), que tenga como valor por defecto NULL, y modificar la ficha de "Roberto Linares" para indicar que su antigedad es de 4 aos.
ALTER TABLE jugador ADD ( antiguedad INT DEFAULT NULL) UPDATE jugador SET antiguedad=4 WHERE nombre="Roberto" AND apellido1="Linares"