Diferència entre revisions de la pàgina «M2 - Bases de dades / Exercicis UF2: Llenguatges SQL / Solucions T7-2»

De wikiserver
Dreceres ràpides: navegació, cerca
 
(Hi ha 9 revisions intermèdies del mateix usuari que no es mostren)
Línia 34: Línia 34:
 
<pre>
 
<pre>
 
- Obtenim el que ha venut cada empleat:
 
- Obtenim el que ha venut cada empleat:
 +
 +
        SELECT e.empno, SUM(nvl(o.total,0))
 +
        FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
 +
                  LEFT OUTER JOIN  ord o ON c.custid = o.custid
 +
        GROUP BY e.empno;
 +
 +
- Calculem el que han venut en mitja tots els empleats:
 +
 +
SELECT AVG(SUM(nvl(o.total,0)))
 +
        FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
 +
                  LEFT OUTER JOIN  ord o ON c.custid = o.custid
 +
        GROUP BY e.empno;
 +
 +
-  Cada empleat amb el que ha venut:
 +
 +
SELECT e.empno, e.ename, avemp.totvenut
 +
FROM emp e, (SELECT empno, (SUM(nvl(o.total,0))) totvenut
 +
                    FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
 +
                                LEFT OUTER JOIN  ord o ON c.custid = o.custid
 +
                    GROUP BY empno) avemp
 +
WHERE e.empno = avemp.empno;
 +
 +
-  Unim-lo  tot:
 +
 +
SELECT e.empno, e.ename, avemp.totvenut
 +
FROM emp e, (SELECT empno, (SUM(nvl(o.total,0))) totvenut
 +
                    FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
 +
                                LEFT OUTER JOIN  ord o ON c.custid = o.custid
 +
                    GROUP BY empno) avemp
 +
        WHERE e.empno = avemp.empno
 +
                      AND avemp.totvenut < (SELECT AVG(SUM(nvl(o.total,0)))
 +
                                            FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
 +
                                                      LEFT OUTER JOIN  ord o ON c.custid = o.custid
 +
                                            GROUP BY empno);
  
SELECT empno, SUM(nvl(o.total,0))  
+
</pre>
 +
<!--
 +
<pre>
 +
- Obtenim el que ha venut cada empleat:
 +
 
 +
 +
        SELECT empno, SUM(nvl(o.total,0))  
 
FROM emp e, customer c, ord o
 
FROM emp e, customer c, ord o
 
WHERE e.empno = c.repid (+) AND c.custid = o.custid (+)
 
WHERE e.empno = c.repid (+) AND c.custid = o.custid (+)
Línia 70: Línia 110:
 
                                                                 GROUP BY empno);
 
                                                                 GROUP BY empno);
 
</pre>
 
</pre>
 +
-->
 
4.Quantitat de producte venut. Ordenat per producte.
 
4.Quantitat de producte venut. Ordenat per producte.
 
<pre>
 
<pre>
Línia 127: Línia 168:
 
</pre>
 
</pre>
 
11.Màximes quantitats de cada producte venudes en una sola comanda. Ordenades de forma ascendent.
 
11.Màximes quantitats de cada producte venudes en una sola comanda. Ordenades de forma ascendent.
 +
 +
<pre>
 +
SELECT p.descrip, MAX(i.qty) "Max_Qty"
 +
FROM product p NATURAL JOIN item i
 +
GROUP BY p.descrip
 +
ORDER BY "Max_Qty" ASC;
 +
</pre>
 +
<!--
 
<pre>
 
<pre>
 
SELECT p.descrip, MAX(i.qty) "Max_Qty"
 
SELECT p.descrip, MAX(i.qty) "Max_Qty"
Línia 134: Línia 183:
 
ORDER BY "Max_Qty" ASC;
 
ORDER BY "Max_Qty" ASC;
 
</pre>
 
</pre>
 +
-->
 +
12.Mostrar quantitat de cada producte venut. Només ens interessen aquells productes dels que s'hagin venut més de 8 unitats.
  
12.Mostrar quantitat de cada producte venut. Només ens interessen aquells productes dels que s'hagin venut més de 8 unitats.
+
<pre>
 +
SELECT p.descrip, SUM(i.qty) "UNITATS VENUDES"
 +
FROM product p NATURAL JOIN item i
 +
GROUP BY p.descrip
 +
HAVING sum(i.qty) > 8;
 +
</pre>
 +
<!--
 
<pre>
 
<pre>
 
SELECT p.descrip, SUM(i.qty) "UNITATS VENUDES"
 
SELECT p.descrip, SUM(i.qty) "UNITATS VENUDES"
Línia 143: Línia 200:
 
HAVING sum(i.qty) > 8;
 
HAVING sum(i.qty) > 8;
 
</pre>
 
</pre>
 +
-->
 
13.Quantitat de producte venut. Ordenat per producte. Han d'aparèixer tots els productes.
 
13.Quantitat de producte venut. Ordenat per producte. Han d'aparèixer tots els productes.
 +
 +
<pre>
 +
SELECT p.descrip, SUM(i.qty) "UNITATS VENUDES"
 +
FROM product p LEFT OUTER JOIN item i
 +
ON p.prodid = i.prodid
 +
GROUP BY p.descrip
 +
ORDER BY p.descrip;
 +
</pre>
 +
<!--
 
<pre>
 
<pre>
 
SELECT p.descrip, SUM(i.qty) "UNITATS VENUDES"
 
SELECT p.descrip, SUM(i.qty) "UNITATS VENUDES"
Línia 151: Línia 218:
 
ORDER BY p.descrip;
 
ORDER BY p.descrip;
 
</pre>
 
</pre>
 +
-->
 
14.Quantitat de producte venut per empleat.
 
14.Quantitat de producte venut per empleat.
 +
 +
<pre>
 +
SELECT p.descrip, e.ename, SUM(i.qty) "UNITATS VENUDES"
 +
FROM product p JOIN item i ON p.prodid = i.prodid
 +
            JOIN ord o ON i.ordid = o.ordid
 +
            JOIN customer c ON o.custid = c.custid
 +
            JOIN emp e ON c.repid = e.empno
 +
GROUP BY p.descrip, e.ename
 +
ORDER BY p.descrip;
 +
</pre>
 +
<!--
 
<pre>
 
<pre>
 
SELECT p.descrip, e.ename, SUM(i.qty) "UNITATS VENUDES"
 
SELECT p.descrip, e.ename, SUM(i.qty) "UNITATS VENUDES"
Línia 160: Línia 239:
 
ORDER BY p.descrip;
 
ORDER BY p.descrip;
 
</pre>
 
</pre>
 
+
-->
 
15.Número d'ordres de cada COMMPLAN.
 
15.Número d'ordres de cada COMMPLAN.
 
<pre>
 
<pre>
Línia 168: Línia 247:
 
</pre>
 
</pre>
 
16.Número de productes venuts a cada ordre. Han d'aparèixer totes les ordres.
 
16.Número de productes venuts a cada ordre. Han d'aparèixer totes les ordres.
 +
 +
<pre>
 +
SELECT o.ordid, COUNT(i.itemid)
 +
FROM ord o LEFT OUTER JOIN item i
 +
    ON o.ordid = i.ordid
 +
GROUP BY o.ordid
 +
ORDER BY o.ordid;
 +
</pre>
 +
<!--
 
<pre>
 
<pre>
 
SELECT o.ordid, COUNT(i.itemid)
 
SELECT o.ordid, COUNT(i.itemid)
Línia 175: Línia 263:
 
ORDER BY o.ordid;
 
ORDER BY o.ordid;
 
</pre>
 
</pre>
 +
-->
 
17. Clients que han comprat més de 5 unitats d'algun producte en una comanda (EXISTS).
 
17. Clients que han comprat més de 5 unitats d'algun producte en una comanda (EXISTS).
 +
 +
<pre>
 +
SELECT custid
 +
FROM customer c
 +
WHERE EXISTS (SELECT ordid
 +
      FROM ord o NATURAL JOIN item i
 +
              WHERE o.custid = c.custid and i.qty > 10);
 +
</pre>
 +
<!--
 
<pre>
 
<pre>
 
SELECT custid
 
SELECT custid
Línia 183: Línia 281:
 
               WHERE o.custid = c.custid and o.ordid = i.ordid and i.qty > 10);
 
               WHERE o.custid = c.custid and o.ordid = i.ordid and i.qty > 10);
 
</pre>
 
</pre>
 +
-->
 +
18. Quins clients han comprat més que la mitjana.
  
18. Quins clients han comprat més que la mitjana.
+
<pre>
 +
SELECT c.name
 +
FROM customer c NATURAL JOIN ord O
 +
GROUP BY c.name
 +
HAVING SUM(o.total) > (SELECT AVG(SUM(o1.total))
 +
                      FROM ord o1
 +
                      GROUP BY o1.custid);
 +
</pre>
 +
<!--
 
<pre>
 
<pre>
 
SELECT c.name
 
SELECT c.name
Línia 194: Línia 302:
 
                       GROUP BY o1.custid);
 
                       GROUP BY o1.custid);
 
</pre>
 
</pre>
 +
-->
 
19. Quants clients han comprat més que la mitjana.
 
19. Quants clients han comprat més que la mitjana.
 +
 
<pre>
 
<pre>
SELECT COUNT(COUNT(c.name))
+
SELECT COUNT(COUNT(c.name)) "NUM CLIENTES"
 +
FROM customer c NATURAL JOIN ord O
 +
GROUP BY c.name
 +
HAVING SUM(o.total) > (SELECT AVG(SUM(o1.total))
 +
                      FROM ord o1
 +
                      GROUP BY o1.custid);
 +
</pre>
 +
<!--
 +
<pre>
 +
SELECT COUNT(COUNT(c.name)) "NUM CLIENTES"
 
FROM customer c, ord O
 
FROM customer c, ord O
 
WHERE c.custid = o.custid  
 
WHERE c.custid = o.custid  
Línia 204: Línia 323:
 
                       GROUP BY o1.custid);
 
                       GROUP BY o1.custid);
 
</pre>
 
</pre>
 +
-->
 
20. Quants empleats no cobren comissió a cada departament. Han d'apareixer tots els departaments.
 
20. Quants empleats no cobren comissió a cada departament. Han d'apareixer tots els departaments.
 +
 
<pre>
 
<pre>
SELECT d.deptno, count(e.empno)
+
SELECT d.deptno, count(e.empno) "NO COMISSIÓ"
 +
FROM dept d LEFT OUTER JOIN emp e
 +
    ON d.deptno = e.deptno
 +
WHERE e.comm is null
 +
GROUP BY d.deptno; 
 +
</pre>
 +
<!--
 +
<pre>
 +
SELECT d.deptno, count(e.empno) "NO COMISSIÓ"
 
FROM dept d, emp e
 
FROM dept d, emp e
 
WHERE d.deptno = e.deptno (+) and e.comm is null
 
WHERE d.deptno = e.deptno (+) and e.comm is null
 
GROUP BY d.deptno;
 
GROUP BY d.deptno;
 
</pre>
 
</pre>
 +
-->
 
21. Mostrar el prodid dels productes que no s'han venut mai (MINUS).
 
21. Mostrar el prodid dels productes que no s'han venut mai (MINUS).
 
<pre>
 
<pre>
Línia 220: Línia 350:
 
</pre>
 
</pre>
 
22. Mostrar el prodid i la descripció  dels productes que no s'han venut mai (MINUS).
 
22. Mostrar el prodid i la descripció  dels productes que no s'han venut mai (MINUS).
 +
 +
<pre>
 +
SELECT prodid, descrip
 +
FROM product
 +
MINUS
 +
SELECT prodid, descrip
 +
FROM item NATURAL JOIN product;
 +
</pre>
 +
<!--
 
<pre>
 
<pre>
 
SELECT prodid, descrip
 
SELECT prodid, descrip
Línia 228: Línia 367:
 
WHERE ITEM.PRODID=PRODUCT.PRODID;
 
WHERE ITEM.PRODID=PRODUCT.PRODID;
 
</pre>
 
</pre>
 +
-->
 
<!---->
 
<!---->

Revisió de 13:06, 16 nov 2022

1.Quantitat de producte venuda a cada client.

	SELECT o.custid, i.prodid, sum(i.qty) "Qtat Producte"
 	FROM ord o NATURAL JOIN item i
	GROUP BY o.custid, i.prodid
	ORDER BY o.custid;

2.Import total venut per cada empleat.

	
	SELECT c.repid, sum(o.total) "Total Venut"
	FROM customer c NATURAL JOIN ord o
	GROUP BY c.repid
	ORDER BY c.repid;

3.Empleats que han venut menys que la mitja de tots els empleats.

	
	- Obtenim el que ha venut cada empleat:
	
        SELECT e.empno, SUM(nvl(o.total,0)) 
        FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
                   LEFT OUTER JOIN  ord o ON c.custid = o.custid
        GROUP BY e.empno;

	- Calculem el que han venut en mitja tots els empleats:

	SELECT AVG(SUM(nvl(o.total,0)))
        FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
                   LEFT OUTER JOIN  ord o ON c.custid = o.custid
        GROUP BY e.empno;

	-  Cada empleat amb el que ha venut:
	
	SELECT e.empno, e.ename, avemp.totvenut
	FROM emp e, (SELECT empno, (SUM(nvl(o.total,0))) totvenut
                     FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
                                LEFT OUTER JOIN  ord o ON c.custid = o.custid
                     GROUP BY empno) avemp
	WHERE e.empno = avemp.empno;

	-  Unim-lo  tot:	

	SELECT e.empno, e.ename, avemp.totvenut
	FROM emp e, (SELECT empno, (SUM(nvl(o.total,0))) totvenut
                     FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
                                LEFT OUTER JOIN  ord o ON c.custid = o.custid
                     GROUP BY empno) avemp
        WHERE e.empno = avemp.empno
                      AND avemp.totvenut < (SELECT AVG(SUM(nvl(o.total,0))) 
                                            FROM emp e LEFT OUTER JOIN customer c ON e.empno = c.repid
                                                       LEFT OUTER JOIN  ord o ON c.custid = o.custid
                                            GROUP BY empno);

4.Quantitat de producte venut. Ordenat per producte.

	
	SELECT i.prodid, sum(i.qty) "Total Producte"
	FROM item i
	GROUP BY i.prodid
	ORDER BY i.prodid;

5.Quantitat de producte venut. Ordenat per quantitat de forma descendent. Han d'aparèixer tots els productes.

        SELECT p.prodid, sum(i.qty) "Total Producte"
	FROM product p LEFT OUTER JOIN item i
        ON p.prodid = i.prodid
	GROUP BY p.prodid
	ORDER BY p.prodid DESC;

6.Quants clients a cada estat?

        SELECT c.state, count(c.custid) "Qtat Clients"
        FROM customer c
        GROUP BY c.state;

7.Quantes ordres per any i mes?

         SELECT TO_CHAR(orderdate, 'YYYY MM') "ANY i MES", COUNT(ordid) "Num. Ordres"
         FROM ord
         GROUP BY TO_CHAR(orderdate, 'YYYY')
         ORDER BY TO_CHAR(orderdate, 'YYYY');

8.Quantes ordres per any?

         SELECT TO_CHAR(orderdate, 'YYYY') "ANY", COUNT(ordid) "Num. Ordres"
         FROM ord
         GROUP BY TO_CHAR(orderdate, 'YYYY MM')
         ORDER BY TO_CHAR(orderdate, 'YYYY MM');

9.En quants productes surt la paraula "TENNIS"?

         SELECT COUNT(prodid) "Núm prod amb paraula TENNIS"
         FROM product
         WHERE upper(descrip) LIKE '%TENNIS%';

10.Increment del preus dels productes des del primer preu fins l'actual.


11.Màximes quantitats de cada producte venudes en una sola comanda. Ordenades de forma ascendent.

	SELECT p.descrip, MAX(i.qty) "Max_Qty"
	FROM product p NATURAL JOIN item i 
	GROUP BY p.descrip
	ORDER BY "Max_Qty" ASC;

12.Mostrar quantitat de cada producte venut. Només ens interessen aquells productes dels que s'hagin venut més de 8 unitats.

	SELECT p.descrip, SUM(i.qty) "UNITATS VENUDES"
	FROM product p NATURAL JOIN item i 
	GROUP BY p.descrip
	HAVING sum(i.qty) > 8;

13.Quantitat de producte venut. Ordenat per producte. Han d'aparèixer tots els productes.

	SELECT p.descrip, SUM(i.qty) "UNITATS VENUDES"
	FROM product p LEFT OUTER JOIN item i 
	ON p.prodid = i.prodid 
	GROUP BY p.descrip
	ORDER BY p.descrip;

14.Quantitat de producte venut per empleat.

	SELECT p.descrip, e.ename, SUM(i.qty) "UNITATS VENUDES"
	FROM product p JOIN item i ON p.prodid = i.prodid
             JOIN ord o ON i.ordid = o.ordid
             JOIN customer c ON o.custid = c.custid
             JOIN emp e ON c.repid = e.empno
	GROUP BY p.descrip, e.ename
	ORDER BY p.descrip;

15.Número d'ordres de cada COMMPLAN.

	SELECT commplan, COUNT(ordid)
	FROM ord
	GROUP BY commplan; 	

16.Número de productes venuts a cada ordre. Han d'aparèixer totes les ordres.

	SELECT o.ordid, COUNT(i.itemid)
	FROM ord o LEFT OUTER JOIN item i
	     ON o.ordid = i.ordid
	GROUP BY o.ordid
	ORDER BY o.ordid;

17. Clients que han comprat més de 5 unitats d'algun producte en una comanda (EXISTS).

SELECT custid
FROM customer c
WHERE EXISTS (SELECT ordid
	      FROM ord o NATURAL JOIN item i
              WHERE o.custid = c.custid and i.qty > 10);

18. Quins clients han comprat més que la mitjana.

SELECT c.name
FROM customer c NATURAL JOIN ord O
GROUP BY c.name
HAVING SUM(o.total) > (SELECT AVG(SUM(o1.total))
                      FROM ord o1
                      GROUP BY o1.custid);

19. Quants clients han comprat més que la mitjana.

SELECT COUNT(COUNT(c.name)) "NUM CLIENTES"
FROM customer c NATURAL JOIN ord O
GROUP BY c.name
HAVING SUM(o.total) > (SELECT AVG(SUM(o1.total))
                      FROM ord o1
                      GROUP BY o1.custid); 

20. Quants empleats no cobren comissió a cada departament. Han d'apareixer tots els departaments.

SELECT d.deptno, count(e.empno) "NO COMISSIÓ"
FROM dept d LEFT OUTER JOIN emp e
     ON d.deptno = e.deptno
WHERE e.comm is null
GROUP BY d.deptno;  

21. Mostrar el prodid dels productes que no s'han venut mai (MINUS).

SELECT prodid
FROM product
MINUS
SELECT prodid
FROM item;

22. Mostrar el prodid i la descripció dels productes que no s'han venut mai (MINUS).

SELECT prodid, descrip
FROM product
MINUS
SELECT prodid, descrip
FROM item NATURAL JOIN product;