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:
También puedes usar 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:
2. Lista los nombres y los precios de todos los productos de la tabla producto.
Resultado esperado:
3. Lista todas las columnas de la tabla producto.
Resultado esperado:
4. Lista el nombre de los productos, el precio en euros y el precio en dólares estadounidenses (USD).
Resultado esperado:
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:
6. Lista los nombres y los precios de todos los productos de la tabla producto, convirtiendo los nombres a mayúscula.
Resultado esperado:
7. Lista los nombres y los precios de todos los productos de la tabla producto, convirtiendo los nombres a minúscula.
Resultado esperado:
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:
9. Lista los nombres y los precios de todos los productos de la tabla producto, redondeando el valor del precio.
Resultado esperado:
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:
11. Lista el código de los fabricantes que tienen productos en la tabla producto.
Resultado esperado:
12. Lista el código de los fabricantes que tienen productos en la tabla producto, eliminando los códigos que aparecen repetidos.
Resultado esperado:
13. Lista los nombres de los fabricantes ordenados de forma ascendente.
Resultado esperado:
14. Lista los nombres de los fabricantes ordenados de forma descendente.
Resultado esperado:
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:
16. Devuelve una lista con las 5 primeras filas de la tabla fabricante.
Resultado esperado:
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:
18. Lista el nombre y el precio del producto más barato. (Utilice solamente las cláusulas ORDER BY y ROWNUM).
Resultado esperado:
19. Lista el nombre y el precio del producto más caro. (Utilice solamente las cláusulas ORDER BY y ROWNUM).
Resultado esperado:
20. Lista el nombre de todos los productos del fabricante cuyo código de fabricante es igual a 2.
Resultado esperado:
21. Lista el nombre de los productos que tienen un precio menor o igual a 120€.
Resultado esperado:
22. Lista el nombre de los productos que tienen un precio mayor o igual a 400€.
Resultado esperado:
23. Lista el nombre de los productos que no tienen un precio mayor o igual a 400€.
Resultado esperado:
24. Lista todos los productos que tengan un precio entre 80€ y 300€. Sin utilizar el operador BETWEEN.
Resultado esperado:
25. Lista todos los productos que tengan un precio entre 60€ y 200€. Utilizando el operador BETWEEN.
Resultado esperado:
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:
27. Lista todos los productos donde el código de fabricante sea 1, 3 o 5. Sin utilizar el operador IN.
Resultado esperado:
28. Lista todos los productos donde el código de fabricante sea 1, 3 o 5. Utilizando el operador IN.
Resultado esperado:
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:
30. Lista los nombres de los fabricantes cuyo nombre empiece por la letra S.
Resultado esperado:
31. Lista los nombres de los fabricantes cuyo nombre termine por la vocal e.
Resultado esperado:
32. Lista los nombres de los fabricantes cuyo nombre contenga el carácter w.
Resultado esperado:
33. Lista los nombres de los fabricantes cuyo nombre sea de 4 caracteres.
Resultado esperado:
34. Devuelve una lista con el nombre de todos los productos que contienen la cadena Portátil en el nombre.
Resultado esperado:
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:
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:
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:
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:
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:
40. Devuelve el nombre del producto, su precio y el nombre de su fabricante, del producto más barato.
Resultado esperado:
41. Devuelve el nombre del producto, su precio y el nombre de su fabricante, del producto más caro.
Resultado esperado:
42. Devuelve una lista de todos los productos del fabricante Lenovo.
Resultado esperado:
43. Devuelve una lista de todos los productos del fabricante Crucial que tengan un precio mayor que 200€.
Resultado esperado:
44. Devuelve un listado con todos los productos de los fabricantes Asus, Hewlett-Packardy Seagate. Sin utilizar el operador IN.
Resultado esperado:
45. Devuelve un listado con todos los productos de los fabricantes Asus, Hewlett-Packardy Seagate. Utilizando el operador IN.
Resultado esperado:
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:
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:
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:
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:
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:
51. Devuelve un listado donde sólo aparezcan aquellos fabricantes que no tienen ningún producto asociado.
Resultado esperado:
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:
54. Calcula el número total de fabricantes que hay en la tabla fabricante.
Resultado esperado:
55. Calcula el número de valores distintos de código de fabricante aparecen en la tabla productos.
Resultado esperado:
56. Calcula la media del precio de todos los productos.
Resultado esperado:
57. Calcula el precio más barato de todos los productos.
Resultado esperado:
58. Calcula el precio más caro de todos los productos.
Resultado esperado:
59. Lista el nombre y el precio del producto más barato.
Resultado esperado:
60. Lista el nombre y el precio del producto más caro.
Resultado esperado:
61. Calcula la suma de los precios de todos los productos.
Resultado esperado:
62. Calcula el número de productos que tiene el fabricante Asus.
Resultado esperado:
63. Calcula la media del precio de todos los productos del fabricante Asus.
Resultado esperado:
64. Calcula el precio más barato de todos los productos del fabricante Asus.
Resultado esperado:
65. Calcula el precio más caro de todos los productos del fabricante Asus.
Resultado esperado:
66. Calcula la suma de todos los productos del fabricante Asus.
Resultado esperado:
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:
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:
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:
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:
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:
72. Calcula el número de productos que tienen un precio mayor o igual a 180€.
Resultado esperado:
73. Calcula el número de productos que tiene cada fabricante con un precio mayor o igual a 180€.
Resultado esperado:
74. Lista el precio medio de los productos de cada fabricante, mostrando solamente el código del fabricante.
Resultado esperado:
75. Lista el precio medio los productos de cada fabricante, mostrando solamente el nombre del fabricante.
Resultado esperado:
76. Lista los nombres de los fabricantes cuyos productos tienen un precio medio mayor o igual a 150€.
Resultado esperado:
77. Devuelve un listado con los nombres de los fabricantes que tienen 2 o más productos.
Resultado esperado:
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:
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:
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:
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:
82. Devuelve todos los productos del fabricante Lenovo. (Sin utilizar INNER JOIN).
Resultado esperado:
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:
84. Lista el nombre del producto más caro del fabricante Lenovo.
Resultado esperado:
85. Lista el nombre del producto más barato del fabricante Hewlett-Packard.
Resultado esperado:
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:
87. Lista todos los productos del fabricante Asus que tienen un precio superior al precio medio de todos sus productos.
Resultado esperado:
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:
89. Devuelve el producto más caro que existe en la tabla producto sin hacer uso de MAX, ORDER BY ni LIMIT.
Resultado esperado:
90. Devuelve el producto más barato que existe en la tabla producto sin hacer uso de MIN, ORDER BY ni LIMIT.
Resultado esperado:
91. Devuelve los nombres de los fabricantes que tienen productos asociados. (Utilizando ALL o ANY).
Resultado esperado:
92. Devuelve los nombres de los fabricantes que no tienen productos asociados. (Utilizando ALL o ANY).
Resultado esperado:
93. Devuelve los nombres de los fabricantes que tienen productos asociados. (Utilizando IN o NOT IN).
Resultado esperado:
94. Devuelve los nombres de los fabricantes que no tienen productos asociados. (Utilizando IN o NOT IN).
Resultado esperado:
95. Devuelve los nombres de los fabricantes que tienen productos asociados. (Utilizando EXISTS o NOT EXISTS).
Resultado esperado:
96. Devuelve los nombres de los fabricantes que no tienen productos asociados. (Utilizando EXISTS o NOT EXISTS).
Resultado esperado:
97. Lista el nombre de cada fabricante con el nombre y el precio de su producto más caro.
Resultado esperado:
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:
99. Lista el nombre del producto más caro del fabricante Lenovo.
Resultado esperado:
Espero que os sea de ayuda. Si tenéis dudas, preguntad. Estamos para ayudarte.
Deja una respuesta