Ejercicios propuestos y resueltos de consultas Oracle (Jardinería)

Hola a todos, hoy os dejo una serie de ejercicios sobre la base de datos oracle.

Todos los ejercicios que proponemos están resueltos en este mismo post, intenta hacerlo por ti mismo y si te quedas atascado puedes mirar la solución. Recuerda, que no tiene por que estar igual tu solución con la del post, el objetivo es que aprendas no que me copies la solución.

Aquí te dejo la base de datos de jardinería que debes importar

Os dejo el modelo Entidad – Relación de la base de datos:

1. Muestra la ciudad y el codigo postal de las oficinas de España.

Spoiler Inside SelectShow>

2. Obtener el nombre y apellidos del jefe de la empresa.

Spoiler Inside SelectShow>

3. Mostrar el nombre y cargo de los empleados que no sean directores de oficina.

Spoiler Inside SelectShow>

4. Muestra el número de empleados que hay en la empresa.

Spoiler Inside SelectShow>

5. Muestra el número de clientes norteamericanos.

Spoiler Inside SelectShow>

6. Número de clientes de cada país.

Spoiler Inside SelectShow>

7. Muestra el nombre del cliente y el nombre de su representante de ventas (si lo tiene).

Spoiler Inside SelectShow>

8. Nombre de los clientes que hayan hecho un pago en 2007

Spoiler Inside SelectShow>

9. Los posibles estados de un pedido.

Spoiler Inside SelectShow>

10. Muestra el número de pedido, el nombre del cliente, la fecha de entrega y la fecha requerida  de los pedidos que no han sido entregados a tiempo.

Spoiler Inside SelectShow>

11. Muestra el código, nombre y gama de los productos que nunca se han pedido (detalle pedidos).

Spoiler Inside SelectShow>

12. Muestra el nombre y apellidos de los empleados que trabajan en Barcelona.

Spoiler Inside SelectShow>

13. Muestra el código y la cantidad de veces que se ha pedido un producto al menos una vez.

Spoiler Inside SelectShow>

14. Muestra el nombre de los clientes de Miami que han realizado algún pedido.

Spoiler Inside SelectShow>

15. Mostrar el precio final de cada pedido.

Spoiler Inside SelectShow>

16. Mostrar lo que ha pagado cada cliente.

Spoiler Inside SelectShow>

17. Mostrar el numero de productos de cada gama.

Spoiler Inside SelectShow>

18. Mostrar el codigo de los pedidos donde se haya vendido el producto de la gama ‘Aromáticas’ mas caro.

Spoiler Inside SelectShow>

19. Mostrar el codigo de los pedidos donde se hayan vendido mas de 6 productos.

Spoiler Inside SelectShow>

20. Mostrar el codigo de los pedidos donde el precio del pedido sea superior a la media de todos los pedidos.

Spoiler Inside SelectShow>

21. Realiza una vista que muestre los datos de un empleado (nombre, apellidos, ciudad de la oficina) y lo mismo para su jefe (en la misma fila).

Spoiler Inside SelectShow>

22. Realiza una vista que muestre el codigo de pedido y su total en euros.

Spoiler Inside SelectShow>

23. Realiza una vista con la información del pedido (codigo, fechapedido, fechaesperada, fechaentrega, nombre cliente y total en euros) ordenado por total de forma descendente.

Spoiler Inside SelectShow>

24. Devolverme la gama de productos mas vendida. Sin vistas

Spoiler Inside SelectShow>

25. Devolverme la gama de productos mas vendida. Usa vistas

Spoiler Inside SelectShow>

26. Muestra el pais(cliente) donde menos pedidos se hacen.

Spoiler Inside SelectShow>

Espero que os sea de ayuda. Si tenéis cualquier duda, no dudes en preguntar. Estamos para ayudarte.

Etiquetas

22 comments

  1. Hola Fernando, primeramente felicitarte y agradecerte por el aporte que haces a esta comunidad que tiene deseos de aprende. Quería solicitarte tu ayuda en la explicación paso a paso del ejercicio 20, me he confundido en los filtros que utilizaste ya que no usas campos específicos para hacer el comparativo, bueno espero me puedas ayudar. Saludos…

  2. La idea es sacar primero la media de todos los pedidos primero:

    (select avg(t.total)
    from (select p.codigopedido, sum(dp.cantidad * dp.PRECIOUNIDAD) as total
    from pedidos p, detallepedidos dp
    where p.codigopedido = dp.codigopedido
    group by p.codigopedido) t);

    y para cada pedido debes sacar su valor.

    (select sum(dp.cantidad * dp.PRECIOUNIDAD) as total
    from pedidos p, detallepedidos dp
    where p.codigopedido = dp.codigopedido and pe.codigopedido = p.codigopedido
    group by p.codigopedido)

    Ya simplemente es compararlos, saludos.

  3. Muchas gracias muy buen aporte sería de mucho más ayuda si en la creación de la base de datos explicas el uso de cada comando.

  4. No sabras como se hacen los disparadaores y paquetes

  5. No puedo descargar la base de datos, no funciona el link

  6. Hola, el enlace no funciona, redirige a una pagina, ¿me lo puedes enviar por mail por favor?

  7. La base de datos si se puede descargar, deden revisar si su navegador esta bloqueando la descarga o cambiarse a otro navegador que les permita realizar la descarga.

    Saludos.

  8. Hola,
    ¿A alguien le funciona el enlace de descarga de la base de datos? Soy incapaz de descargarla.
    Un saludo

  9. 11. Devuelve el nombre, apellido1 y cargo de los empleados que no representen a ningún cliente.

  10. Hola, en caso de, que a este ejercicio quisiera agregarle un trigger que no permita modificar el precio de venta de un producto si es inferior al precio del proveedor, como lo haria?

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *