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

De wikiserver
Dreceres ràpides: navegació, cerca
(Es crea la pàgina amb «1. Escriu una consulta que mostri el nom, número de departament i salari de qualsevol empleat, que tinguin un número de departament i salari que es corresponguin -els d…».)
 
Línia 37: Línia 37:
 
SELECT ename, job, sal
 
SELECT ename, job, sal
 
FROM emp
 
FROM emp
WHERE sal > ALL (SELECT sal
+
WHERE sal > ANY (SELECT sal
 
                 FROM emp
 
                 FROM emp
 
                 WHERE lower(job) = 'clerk')     
 
                 WHERE lower(job) = 'clerk')     

Revisió del 16:55, 21 gen 2014

1. Escriu una consulta que mostri el nom, número de departament i salari de qualsevol empleat, que tinguin un número de departament i salari que es corresponguin -els dos- amb el número de departament i salari de qualsevol empleat que tingui comissió.

SELECT ename, deptno, sal
FROM emp
WHERE (deptno, sal) IN
      (SELECT deptno, sal
       FROM emp
       WHERE comm IS NOT NULL);

2. Mostra el nom, nom del departament i salari, de qualsevol empleat que tingui un salari i comissió que es corresponguin -els dos-, amb el salari i comissió de qualsevol empleat de Dallas.

SELECT ename, dname, sal
FROM emp, dept
WHERE emp.deptno = dept.deptno
    AND (sal, nvl(comm,-1)) IN
      (SELECT sal , nvl(comm,-1)
       FROM emp, dept
       WHERE emp.deptno = dept.deptno 
       AND loc = 'DALLAS');

3. Fes una consulta per mostrar el nom, data d'alta i salari de tots els empleats que tinguin el mateix salari i comissió que Scott.

SELECT ename, hiredate, sal
FROM emp
WHERE (sal, nvl(comm,-1)) = 
      (SELECT sal , nvl(comm,-1)
       FROM emp
       WHERE upper(ename) = 'SCOTT')
    AND upper(ename) <> 'SCOTT';

4. Fes una consulta per mostrar als empleats que guanyin un salari superior al salari de qualsevol empleat "CLERK". Ordena el resultat pel salari de forma descendent.

SELECT ename, job, sal
FROM emp
WHERE sal > ANY (SELECT sal
                 FROM emp
                 WHERE lower(job) = 'clerk')    
    AND lower(job) <> 'clerk'
ORDER BY sal DESC;