Ejercicios Propuestos Y Resueltos Tienda Oracle

Hola a todos, hoy os dejo ejercicios propuestos y resueltos de la base de datos de tienda en 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 tienda que debes importar.

Si no tienes instalado oracle database XE, os dejo algunos manuales:

Como instalar Oracle Database XE en Windows

Como instalar SQL Developer en Windows

También puedes usar Oracle Live.

Como utilizar Oracle Live

Al final de cada ejercicio, os indico el resultado esperado de la consulta. Si hay muchos datos, indico el numero de filas.

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

1. Lista el nombre de todos los productos que hay en la tabla producto.

Resultado esperado:

Spoiler Inside SelectShow>

2. Lista los nombres y los precios de todos los productos de la tabla producto.

Resultado esperado:

Spoiler Inside SelectShow>

3. Lista todas las columnas de la tabla producto.

Resultado esperado:

Spoiler Inside SelectShow>

4. Lista el nombre de los productos, el precio en euros y el precio en dólares estadounidenses (USD).

Resultado esperado:

Spoiler Inside SelectShow>

5. Lista el nombre de los productos, el precio en euros y el precio en dólares estadounidenses (USD). Utiliza los siguientes alias para las columnas: nombre de producto, euros, dólares.

Resultado esperado:

Spoiler Inside SelectShow>

6. Lista los nombres y los precios de todos los productos de la tabla producto, convirtiendo los nombres a mayúscula.

Resultado esperado:

Spoiler Inside SelectShow>

7. Lista los nombres y los precios de todos los productos de la tabla producto, convirtiendo los nombres a minúscula.

Resultado esperado:

Spoiler Inside SelectShow>

8. Lista el nombre de todos los fabricantes en una columna, y en otra columna obtenga en mayúsculas los dos primeros caracteres del nombre del fabricante.

Resultado esperado:

Spoiler Inside SelectShow>

9. Lista los nombres y los precios de todos los productos de la tabla producto, redondeando el valor del precio.

Resultado esperado:

Spoiler Inside SelectShow>

10. Lista los nombres y los precios de todos los productos de la tabla producto, truncando el valor del precio para mostrarlo sin ninguna cifra decimal.

Resultado esperado:

Spoiler Inside SelectShow>

11. Lista el código de los fabricantes que tienen productos en la tabla producto.

Resultado esperado:

Spoiler Inside SelectShow>

12. Lista el código de los fabricantes que tienen productos en la tabla producto, eliminando los códigos que aparecen repetidos.

Resultado esperado:

Spoiler Inside SelectShow>

13. Lista los nombres de los fabricantes ordenados de forma ascendente.

Resultado esperado:

Spoiler Inside SelectShow>

14. Lista los nombres de los fabricantes ordenados de forma descendente.

Resultado esperado:

Spoiler Inside SelectShow>

15. Lista los nombres de los productos ordenados en primer lugar por el nombre de forma ascendente y en segundo lugar por el precio de forma descendente.

Resultado esperado:

Spoiler Inside SelectShow>

16. Devuelve una lista con las 5 primeras filas de la tabla fabricante.

Resultado esperado:

Spoiler Inside SelectShow>

17. Devuelve una lista con 2 filas a partir de la cuarta fila de la tabla fabricante. La cuarta fila también se debe incluir en la respuesta.

Resultado esperado:

Spoiler Inside SelectShow>

18. Lista el nombre y el precio del producto más barato. (Utilice solamente las cláusulas ORDER BY y ROWNUM).

Resultado esperado:

Spoiler Inside SelectShow>

19. Lista el nombre y el precio del producto más caro. (Utilice solamente las cláusulas ORDER BY y ROWNUM).

Resultado esperado:

Spoiler Inside SelectShow>

20. Lista el nombre de todos los productos del fabricante cuyo código de fabricante es igual a 2.

Resultado esperado:

Spoiler Inside SelectShow>

21. Lista el nombre de los productos que tienen un precio menor o igual a 120€.

Resultado esperado:

Spoiler Inside SelectShow>

22. Lista el nombre de los productos que tienen un precio mayor o igual a 400€.

Resultado esperado:

Spoiler Inside SelectShow>

23. Lista el nombre de los productos que no tienen un precio mayor o igual a 400€.

Resultado esperado:

Spoiler Inside SelectShow>

24. Lista todos los productos que tengan un precio entre 80€ y 300€. Sin utilizar el operador BETWEEN.

Resultado esperado:

Spoiler Inside SelectShow>

25. Lista todos los productos que tengan un precio entre 60€ y 200€. Utilizando el operador BETWEEN.

Resultado esperado:

Spoiler Inside SelectShow>

26. Lista todos los productos que tengan un precio mayor que 200€ y que el código de fabricante sea igual a 6.

Resultado esperado:

Spoiler Inside SelectShow>

27. Lista todos los productos donde el código de fabricante sea 1, 3 o 5. Sin utilizar el operador IN.

Resultado esperado:

Spoiler Inside SelectShow>

28. Lista todos los productos donde el código de fabricante sea 1, 3 o 5. Utilizando el operador IN.

Resultado esperado:

Spoiler Inside SelectShow>

29. Lista el nombre y el precio de los productos en céntimos (Habrá que multiplicar por 100 el valor del precio). Cree un alias para la columna que contiene el precio que se llame céntimos.

Resultado esperado:

Spoiler Inside SelectShow>

30. Lista los nombres de los fabricantes cuyo nombre empiece por la letra S.

Resultado esperado:

Spoiler Inside SelectShow>

31. Lista los nombres de los fabricantes cuyo nombre termine por la vocal e.

Resultado esperado:

Spoiler Inside SelectShow>

32. Lista los nombres de los fabricantes cuyo nombre contenga el carácter w.

Resultado esperado:

Spoiler Inside SelectShow>

33. Lista los nombres de los fabricantes cuyo nombre sea de 4 caracteres.

Resultado esperado:

Spoiler Inside SelectShow>

34. Devuelve una lista con el nombre de todos los productos que contienen la cadena Portátil en el nombre.

Resultado esperado:

Spoiler Inside SelectShow>

35. Devuelve una lista con el nombre de todos los productos que contienen la cadena Monitor en el nombre y tienen un precio inferior a 215 €.

Resultado esperado:

Spoiler Inside SelectShow>

36. Lista el nombre y el precio de todos los productos que tengan un precio mayor o igual a 180€. Ordene el resultado en primer lugar por el precio (en orden descendente) y en segundo lugar por el nombre (en orden ascendente).

Resultado esperado:

Spoiler Inside SelectShow>

37. Devuelve una lista con el nombre del producto, precio y nombre de fabricante de todos los productos de la base de datos.

Resultado esperado:

Spoiler Inside SelectShow>

38. Devuelve una lista con el nombre del producto, precio y nombre de fabricante de todos los productos de la base de datos. Ordene el resultado por el nombre del fabricante, por orden alfabético.

Resultado esperado:

Spoiler Inside SelectShow>

39. Devuelve una lista con el código del producto, nombre del producto, código del fabricante y nombre del fabricante, de todos los productos de la base de datos.

Resultado esperado:

Spoiler Inside SelectShow>

40. Devuelve el nombre del producto, su precio y el nombre de su fabricante, del producto más barato.

Resultado esperado:

Spoiler Inside SelectShow>

41. Devuelve el nombre del producto, su precio y el nombre de su fabricante, del producto más caro.

Resultado esperado:

Spoiler Inside SelectShow>

42. Devuelve una lista de todos los productos del fabricante Lenovo.

Resultado esperado:

Spoiler Inside SelectShow>

43. Devuelve una lista de todos los productos del fabricante Crucial que tengan un precio mayor que 200€.

Resultado esperado:

Spoiler Inside SelectShow>

44. Devuelve un listado con todos los productos de los fabricantes Asus, Hewlett-Packardy Seagate. Sin utilizar el operador IN.

Resultado esperado:

Spoiler Inside SelectShow>

45. Devuelve un listado con todos los productos de los fabricantes Asus, Hewlett-Packardy Seagate. Utilizando el operador IN.

Resultado esperado:

Spoiler Inside SelectShow>

46. Devuelve un listado con el nombre y el precio de todos los productos de los fabricantes cuyo nombre termine por la vocal e.

Resultado esperado:

Spoiler Inside SelectShow>

47. Devuelve un listado con el nombre y el precio de todos los productos cuyo nombre de fabricante contenga el carácter w en su nombre.

Resultado esperado:

Spoiler Inside SelectShow>

48. Devuelve un listado con el nombre de producto, precio y nombre de fabricante, de todos los productos que tengan un precio mayor o igual a 180€. Ordene el resultado en primer lugar por el precio (en
orden descendente) y en segundo lugar por el nombre (en orden ascendente)

Resultado esperado:

Spoiler Inside SelectShow>

49. Devuelve un listado con el código y el nombre de fabricante, solamente de aquellos fabricantes que tienen productos asociados en la base de datos.

Resultado esperado:

Spoiler Inside SelectShow>

50. Devuelve un listado de todos los fabricantes que existen en la base de datos, junto con los productos que tiene cada uno de ellos. El listado deberá mostrar también aquellos fabricantes que no tienen productos asociados.

Resultado esperado:

Spoiler Inside SelectShow>

51. Devuelve un listado donde sólo aparezcan aquellos fabricantes que no tienen ningún producto asociado.

Resultado esperado:

Spoiler Inside SelectShow>

52. ¿Pueden existir productos que no estén relacionados con un fabricante? Justifica tu respuesta.

En este caso no, ya que la representación del modelo indica que es 1:N, que significa que siempre debe estar un producto asociado a un fabricante y que varios fabricantes pueden tener varios productos.

53. Calcula el número total de productos que hay en la tabla productos.

Resultado esperado:

Spoiler Inside SelectShow>

54. Calcula el número total de fabricantes que hay en la tabla fabricante.

Resultado esperado:

Spoiler Inside SelectShow>

55. Calcula el número de valores distintos de código de fabricante aparecen en la tabla productos.

Resultado esperado:

Spoiler Inside SelectShow>

56. Calcula la media del precio de todos los productos.

Resultado esperado:

Spoiler Inside SelectShow>

57. Calcula el precio más barato de todos los productos.

Resultado esperado:

Spoiler Inside SelectShow>

58. Calcula el precio más caro de todos los productos.

Resultado esperado:

Spoiler Inside SelectShow>

59. Lista el nombre y el precio del producto más barato.

Resultado esperado:

Spoiler Inside SelectShow>

60. Lista el nombre y el precio del producto más caro.

Resultado esperado:

Spoiler Inside SelectShow>

61. Calcula la suma de los precios de todos los productos.

Resultado esperado:

Spoiler Inside SelectShow>

62. Calcula el número de productos que tiene el fabricante Asus.

Resultado esperado:

Spoiler Inside SelectShow>

63. Calcula la media del precio de todos los productos del fabricante Asus.

Resultado esperado:

Spoiler Inside SelectShow>

64. Calcula el precio más barato de todos los productos del fabricante Asus.

Resultado esperado:

Spoiler Inside SelectShow>

65. Calcula el precio más caro de todos los productos del fabricante Asus.

Resultado esperado:

Spoiler Inside SelectShow>

66. Calcula la suma de todos los productos del fabricante Asus.

Resultado esperado:

Spoiler Inside SelectShow>

67. Muestra el precio máximo, precio mínimo, precio medio y el número total de productos que tiene el fabricante Crucial.

Resultado esperado:

Spoiler Inside SelectShow>

68. Muestra el número total de productos que tiene cada uno de los fabricantes.El listado también debe incluir los fabricantes que no tienen ningún producto. El resultado mostrará dos columnas, una con el nombre del fabricante y otra con el número de productos que tiene. Ordene el resultado descendentemente por el número de productos.

Resultado esperado:

Spoiler Inside SelectShow>

69. Muestra el precio máximo, precio mínimo y precio medio de los productos de cada uno de los fabricantes. El resultado mostrará el nombre del fabricante junto con los datos que se solicitan.

Resultado esperado:

Spoiler Inside SelectShow>

70. Muestra el precio máximo, precio mínimo, precio medio y el número total de productos de los fabricantes que tienen un precio medio superior a 200€. No es necesario mostrar el nombre del fabricante, con el código del fabricante es suficiente.

Resultado esperado:

Spoiler Inside SelectShow>

71. Muestra el nombre de cada fabricante, junto con el precio máximo, precio mínimo, precio medio y el número total de productos de los fabricantes que tienen un precio medio superior a 200€. Es necesario mostrar el nombre del fabricante.

Resultado esperado:

Spoiler Inside SelectShow>

72. Calcula el número de productos que tienen un precio mayor o igual a 180€.

Resultado esperado:

Spoiler Inside SelectShow>

73. Calcula el número de productos que tiene cada fabricante con un precio mayor o igual a 180€.

Resultado esperado:

Spoiler Inside SelectShow>

74. Lista el precio medio de los productos de cada fabricante, mostrando solamente el código del fabricante.

Resultado esperado:

Spoiler Inside SelectShow>

75. Lista el precio medio los productos de cada fabricante, mostrando solamente el nombre del fabricante.

Resultado esperado:

Spoiler Inside SelectShow>

76. Lista los nombres de los fabricantes cuyos productos tienen un precio medio mayor o igual a 150€.

Resultado esperado:

Spoiler Inside SelectShow>

77. Devuelve un listado con los nombres de los fabricantes que tienen 2 o más productos.

Resultado esperado:

Spoiler Inside SelectShow>

78. Devuelve un listado con los nombres de los fabricantes y el número de productos que tiene cada uno con un precio superior o igual a 220 €. No es necesario mostrar el nombre de los fabricantes que no tienen productos que cumplan la condición. Ejemplo del resultado esperado:

nombre total
Lenovo 2
Asus 1
Crucial 1

Resultado esperado:

Spoiler Inside SelectShow>

79. Devuelve un listado con los nombres de los fabricantes y el número de productos que tiene cada uno con un precio superior o igual a 220 €. El listado debe mostrar el nombre de todos los fabricantes, es decir, si hay algún fabricante que no tiene productos con un precio superior o igual a 220€ deberá aparecer en el listado con un valor igual a 0 en el número de productos. Ejemplo del resultado esperado:

nombre total
Lenovo 2
Crucial 1
Asus 1
Huawei 0
Samsung 0
Gigabyte 0
Hewlett-Packard 0
Xiaomi 0
Seagate 0

Resultado esperado:

Spoiler Inside SelectShow>

80. Devuelve un listado con los nombres de los fabricantes donde la suma del precio de todos sus productos es superior a 1000 €.

Resultado esperado:

Spoiler Inside SelectShow>

81. Devuelve un listado con el nombre del producto más caro que tiene cada fabricante. El resultado debe tener tres columnas: nombre del producto, precio y nombre del fabricante. El resultado tiene que estar ordenado alfabéticamente de menor a mayor por el nombre del fabricante.

Resultado esperado:

Spoiler Inside SelectShow>

82. Devuelve todos los productos del fabricante Lenovo. (Sin utilizar INNER JOIN).

Resultado esperado:

Spoiler Inside SelectShow>

83. Devuelve todos los datos de los productos que tienen el mismo precio que el producto más caro del fabricante Lenovo. (Sin utilizar INNER JOIN).

Resultado esperado:

 

Spoiler Inside SelectShow>

84. Lista el nombre del producto más caro del fabricante Lenovo.

Resultado esperado:

Spoiler Inside SelectShow>

85. Lista el nombre del producto más barato del fabricante Hewlett-Packard.

Resultado esperado:

Spoiler Inside SelectShow>

86. Devuelve todos los productos de la base de datos que tienen un precio mayor o igual al producto más caro del fabricante Lenovo.

Resultado esperado:

Spoiler Inside SelectShow>

87. Lista todos los productos del fabricante Asus que tienen un precio superior al precio medio de todos sus productos.

Resultado esperado:

Spoiler Inside SelectShow>

88. Subconsultas (En la cláusula HAVING). Devuelve un listado con todos los nombres de los fabricantes que tienen el mismo número de productos que el fabricante Lenovo.

Resultado esperado:

Spoiler Inside SelectShow>

89. Devuelve el producto más caro que existe en la tabla producto sin hacer uso de MAX, ORDER BY ni LIMIT.

Resultado esperado:

Spoiler Inside SelectShow>

90. Devuelve el producto más barato que existe en la tabla producto sin hacer uso de MIN, ORDER BY ni LIMIT.

Resultado esperado:

Spoiler Inside SelectShow>

91. Devuelve los nombres de los fabricantes que tienen productos asociados. (Utilizando ALL o ANY).

Resultado esperado:

Spoiler Inside SelectShow>

92. Devuelve los nombres de los fabricantes que no tienen productos asociados. (Utilizando ALL o ANY).

Resultado esperado:

Spoiler Inside SelectShow>

93. Devuelve los nombres de los fabricantes que tienen productos asociados. (Utilizando IN o NOT IN).

Resultado esperado:

Spoiler Inside SelectShow>

94. Devuelve los nombres de los fabricantes que no tienen productos asociados. (Utilizando IN o NOT IN).

Resultado esperado:

Spoiler Inside SelectShow>

95. Devuelve los nombres de los fabricantes que tienen productos asociados. (Utilizando EXISTS o NOT EXISTS).

Resultado esperado:

Spoiler Inside SelectShow>

96. Devuelve los nombres de los fabricantes que no tienen productos asociados. (Utilizando EXISTS o NOT EXISTS).

Resultado esperado:

Spoiler Inside SelectShow>

97. Lista el nombre de cada fabricante con el nombre y el precio de su producto más caro.

Resultado esperado:

Spoiler Inside SelectShow>

98. Devuelve un listado de todos los productos que tienen un precio mayor o igual a la media de todos los productos de su mismo fabricante.

Resultado esperado:

Spoiler Inside SelectShow>

99. Lista el nombre del producto más caro del fabricante Lenovo.

Resultado esperado:

Spoiler Inside SelectShow>

Espero que os sea de ayuda. Si tenéis dudas, preguntad. Estamos para ayudarte.

Compartir

Deja una respuesta

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