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

17 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.

Deja un comentario

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