SQL. Puzzles divertenti

Hello, Habr!

Għal aktar minn 3 snin issa ilni ngħallem l-SQL f'diversi ċentri ta' taħriġ, u waħda mill-osservazzjonijiet tiegħi hija li l-istudenti jgħallmu u jifhmu aħjar l-SQL jekk jingħataw biċċa xogħol, u mhux biss qalulhom dwar il-possibbiltajiet u l-pedamenti teoretiċi.

F'dan l-artikolu, ser naqsam miegħek il-lista tiegħi ta 'problemi li nagħti lill-istudenti bħala xogħol tad-dar u li fuqhom nagħmlu diversi tipi ta' brainstorms, li jwassal għal fehim profond u ċar tal-SQL.

SQL. Puzzles divertenti

SQL (ˈɛsˈkjuˈɛl; lingwa ta' mistoqsija strutturata bl-Ingliż) hija lingwa ta' programmar dikjarattiva użata biex toħloq, timmodifika u timmaniġġja d-dejta f'database relazzjonali ġestita minn sistema ta' ġestjoni tad-database xierqa. Aktar dettalji ...

Tista 'taqra dwar SQL minn diversi sorsi.
Dan l-artikolu mhux maħsub biex jgħallemk SQL mill-bidu.

Mela ejja.

Aħna se nużaw il-magħruf Dijagramma HR fl-Oracle bit-tabelli tiegħu (Aktar):

SQL. Puzzles divertenti
Ninnota li aħna se nikkunsidraw biss kompiti SELECT. M'hemm l-ebda kompiti DML jew DDL hawn.

kompiti

Restrizzjoni u Issortjar tad-Data

Tabella ta' l-impjegati. Ikseb lista b'informazzjoni dwar l-impjegati kollha
deċiżjoni

SELECT * FROM employees

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha bl-isem 'David'
deċiżjoni

SELECT *
  FROM employees
 WHERE first_name = 'David';

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha bi job_id ugwali għal 'IT_PROG'
deċiżjoni

SELECT *
  FROM employees
 WHERE job_id = 'IT_PROG'

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha mill-50 dipartiment (department_id) b'salarju (salarju) akbar minn 4000
deċiżjoni

SELECT *
  FROM employees
 WHERE department_id = 50 AND salary > 4000;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha mill-20 u t-30 dipartiment (department_id)
deċiżjoni

SELECT *
  FROM employees
 WHERE department_id = 20 OR department_id = 30;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li l-aħħar ittra tagħhom f'isimhom hija 'a'
deċiżjoni

SELECT *
  FROM employees
 WHERE first_name LIKE '%a';

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha mill-50 u t-80 dipartiment (department_id) li għandhom bonus (il-valur fil-kolonna commission_pct mhuwiex vojt)
deċiżjoni

SELECT *
  FROM employees
 WHERE     (department_id = 50 OR department_id = 80)
       AND commission_pct IS NOT NULL;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li isimhom ikun fih mill-inqas 2 ittri 'n'
deċiżjoni

SELECT *
  FROM employees
 WHERE first_name LIKE '%n%n%';

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li l-ismijiet tagħhom huma itwal minn 4 ittri
deċiżjoni

SELECT *
  FROM employees
 WHERE first_name LIKE '%_____%';

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li s-salarju tagħhom huwa fil-medda minn 8000 sa 9000 (inklużi)
deċiżjoni

SELECT *
  FROM employees
 WHERE salary BETWEEN 8000 AND 9000;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li isimhom fih is-simbolu '%'
deċiżjoni

SELECT *
  FROM employees
 WHERE first_name LIKE '%%%' ESCAPE '';

Tabella ta' l-impjegati. Ikseb lista tal-IDs tal-maniġers kollha
deċiżjoni

SELECT DISTINCT manager_id
  FROM employees
 WHERE manager_id IS NOT NULL;

Tabella ta' l-impjegati. Ikseb lista ta' impjegati bil-pożizzjonijiet tagħhom fil-format: Donald(sh_clerk)
deċiżjoni

SELECT first_name || '(' || LOWER (job_id) || ')' employee FROM employees;

L-użu ta 'Funzjonijiet ta' Ringiela waħda biex Ippersonalizza l-Output

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li l-ismijiet tagħhom huma itwal minn 10 ittri
deċiżjoni

SELECT *
  FROM employees
 WHERE LENGTH (first_name) > 10;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li għandhom l-ittra 'b' f'isimhom (insensittiv għall-każi)
deċiżjoni

SELECT *
  FROM employees
 WHERE INSTR (LOWER (first_name), 'b') > 0;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li isimhom ikun fih mill-inqas 2 ittri 'a'
deċiżjoni

SELECT *
  FROM employees
 WHERE INSTR (LOWER (first_name),'a',1,2) > 0;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li s-salarju tagħhom huwa multiplu ta' 1000
deċiżjoni

SELECT *
  FROM employees
 WHERE MOD (salary, 1000) = 0;

Tabella ta' l-impjegati. Ikseb l-ewwel numru ta' 3 ċifri tan-numru tat-telefon ta' impjegat jekk in-numru tiegħu huwa fil-format XXX.XXX.XXXX
deċiżjoni

SELECT phone_number, SUBSTR (phone_number, 1, 3) new_phone_number
  FROM employees
 WHERE phone_number LIKE '___.___.____';

Tabella tad-Dipartimenti. Ikseb l-ewwel kelma mill-isem tad-dipartiment għal dawk li għandhom aktar minn kelma waħda fl-isem
deċiżjoni

SELECT department_name,
       SUBSTR (department_name, 1, INSTR (department_name, ' ')-1)
           first_word
  FROM departments
 WHERE INSTR (department_name, ' ') > 0;

Tabella ta' l-impjegati. Ikseb l-ismijiet tal-impjegati mingħajr l-ewwel u l-aħħar ittra fl-isem
deċiżjoni

SELECT first_name, SUBSTR (first_name, 2, LENGTH (first_name) - 2) new_name
  FROM employees;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li l-aħħar ittra tagħhom f'isimhom hija 'm' u li isimhom huwa itwal minn 5
deċiżjoni

SELECT *
  FROM employees
 WHERE SUBSTR (first_name, -1) = 'm' AND LENGTH(first_name)>5;

Tabella Doppju. Ikseb id-data tal-Ġimgħa li ġejja
deċiżjoni

SELECT NEXT_DAY (SYSDATE, 'FRIDAY') next_friday FROM DUAL;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li ħadmu għall-kumpanija għal aktar minn 17-il sena
deċiżjoni

SELECT *
  FROM employees
 WHERE MONTHS_BETWEEN (SYSDATE, hire_date) / 12 > 17;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li l-aħħar ċifra tagħhom tan-numru tat-telefon tagħhom hija fard u tikkonsisti fi 3 numri separati b'tikka
deċiżjoni

SELECT *
  FROM employees
 WHERE     MOD (SUBSTR (phone_number, -1), 2) != 0
       AND INSTR (phone_number,'.',1,3) = 0;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li l-valur job_id tagħhom wara s-sinjal '_' għandu mill-inqas 3 karattri, iżda dan il-valur wara l-'_' mhuwiex ugwali għal 'CLERK'
deċiżjoni

SELECT *
  FROM employees
 WHERE     LENGTH (SUBSTR (job_id, INSTR (job_id, '_') + 1)) > 3
       AND SUBSTR (job_id, INSTR (job_id, '_') + 1) != 'CLERK';

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha billi tissostitwixxi '.' kollha fil-valur PHONE_NUMBER fuq '-'
deċiżjoni

SELECT phone_number, REPLACE (phone_number, '.', '-') new_phone_number
  FROM employees;

Użu ta 'Funzjonijiet ta' Konverżjoni u Espressjonijiet Kundizzjonali

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li ġew jaħdmu fl-ewwel jum tax-xahar (kwalunkwe)
deċiżjoni

SELECT *
  FROM employees
 WHERE TO_CHAR (hire_date, 'DD') = '01';

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li ġew jaħdmu fl-2008
deċiżjoni

SELECT *
  FROM employees
 WHERE TO_CHAR (hire_date, 'YYYY') = '2008';

Tabella DOPPJA. Uri d-data ta' għada fil-format: Għada huwa t-Tieni jum ta' Jannar
deċiżjoni

SELECT TO_CHAR (SYSDATE, 'fm""Tomorrow is ""Ddspth ""day of"" Month')     info
  FROM DUAL;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha u d-data li kull impjegat wasal fuq ix-xogħol fil-format: 21 ta' Ġunju, 2007
deċiżjoni

SELECT first_name, TO_CHAR (hire_date, 'fmddth ""of"" Month, YYYY') hire_date
  FROM employees;

Tabella ta' l-impjegati. Ikseb lista ta 'impjegati b'salarji miżjuda b'20%. Uri salarju b'sinjal tad-dollaru
deċiżjoni

SELECT first_name, TO_CHAR (salary + salary * 0.20, 'fm$999,999.00') new_salary
  FROM employees;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha li bdew jaħdmu fi Frar 2007.
deċiżjoni

SELECT *
  FROM employees
 WHERE hire_date BETWEEN TO_DATE ('01.02.2007', 'DD.MM.YYYY')
                     AND LAST_DAY (TO_DATE ('01.02.2007', 'DD.MM.YYYY'));

SELECT *
  FROM employees
 WHERE to_char(hire_date,'MM.YYYY') = '02.2007'; 

Tabella DOPPJA. Oħroġ id-data kurrenti, + sekonda, + minuta, + siegħa, + jum, + xahar, + sena
deċiżjoni

SELECT SYSDATE                          now,
       SYSDATE + 1 / (24 * 60 * 60)     plus_second,
       SYSDATE + 1 / (24 * 60)          plus_minute,
       SYSDATE + 1 / 24                 plus_hour,
       SYSDATE + 1                      plus_day,
       ADD_MONTHS (SYSDATE, 1)          plus_month,
       ADD_MONTHS (SYSDATE, 12)         plus_year
  FROM DUAL;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha b'salarji sħaħ (salarju + commission_pct(%)) fil-format: $24,000.00
deċiżjoni

SELECT first_name, salary, TO_CHAR (salary + salary * NVL (commission_pct, 0), 'fm$99,999.00') full_salary
  FROM employees;

Tabella ta' l-impjegati. Ikseb lista tal-impjegati kollha u informazzjoni dwar id-disponibbiltà tal-bonuses tas-salarju (Iva/Le)
deċiżjoni

SELECT first_name, commission_pct, NVL2 (commission_pct, 'Yes', 'No') has_bonus
  FROM employees;

Tabella ta' l-impjegati. Ikseb il-livell tas-salarju ta' kull impjegat: Inqas minn 5000 huwa kkunsidrat Livell Baxx, Akbar minn jew ugwali għal 5000 u inqas minn 10000 huwa kkunsidrat Livell normali, Aktar minn jew ugwali għal 10000 huwa kkunsidrat Livell Għoli
deċiżjoni

SELECT first_name,
       salary,
       CASE
           WHEN salary < 5000 THEN 'Low'
           WHEN salary >= 5000 AND salary < 10000 THEN 'Normal'
           ELSE 'High'
       END salary_level
  FROM employees;

Tabella Pajjiżi. Għal kull pajjiż, uri r-reġjun li jinsab fih: 1-Ewropa, 2-Amerika, 3-Asja, 4-Afrika (mingħajr Ingħaqad)
deċiżjoni

SELECT country_name country,
       DECODE (region_id,
               1, 'Europe',
               2, 'America',
               3, 'Asia',
               4, 'Africa',
               'Unknown')
           region
  FROM countries;

SELECT country_name
           country,
       CASE region_id
           WHEN 1 THEN 'Europe'
           WHEN 2 THEN 'America'
           WHEN 3 THEN 'Asia'
           WHEN 4 THEN 'Africa'
           ELSE 'Unknown'
       END
           region
  FROM countries;

Rappurtar ta' Dejta Aggregata Bl-Użu tal-Funzjonijiet tal-Grupp

Tabella ta' l-impjegati. Irċievi rapport mid-dipartiment_id bis-salarju minimu u massimu, dati kmieni u tard tal-wasla fuq ix-xogħol u n-numru ta 'impjegati. Issortja skond in-numru ta' impjegati (dixxendenti)
deċiżjoni

  SELECT department_id,
         MIN (salary) min_salary,
         MAX (salary) max_salary,
         MIN (hire_date) min_hire_date,
         MAX (hire_date) max_hire_Date,
         COUNT (*) count
    FROM employees
GROUP BY department_id
order by count(*) desc;

Tabella ta' l-impjegati. Kemm hemm impjegati li isimhom jibda bl-istess ittra? Issortja skond il-kwantità. Uri biss dawk fejn il-kwantità hija akbar minn 1
deċiżjoni

SELECT SUBSTR (first_name, 1, 1) first_char, COUNT (*)
    FROM employees
GROUP BY SUBSTR (first_name, 1, 1)
  HAVING COUNT (*) > 1
ORDER BY 2 DESC;

Tabella ta' l-impjegati. Kemm impjegati jaħdmu fl-istess dipartiment u jirċievu l-istess salarju?
deċiżjoni

SELECT department_id, salary, COUNT (*)
    FROM employees
GROUP BY department_id, salary
  HAVING COUNT (*) > 1;

Tabella ta' l-impjegati. Ikseb rapport ta' kemm ġew impjegati impjegati f'kull jum tal-ġimgħa. Issortja skond il-kwantità
deċiżjoni

SELECT TO_CHAR (hire_Date, 'Day') day, COUNT (*)
    FROM employees
GROUP BY TO_CHAR (hire_Date, 'Day')
ORDER BY 2 DESC;

Tabella ta' l-impjegati. Ikseb rapport ta' kemm ġew impjegati impjegati skont is-sena. Issortja skond il-kwantità
deċiżjoni

SELECT TO_CHAR (hire_date, 'YYYY') year, COUNT (*)
    FROM employees
GROUP BY TO_CHAR (hire_date, 'YYYY');

Tabella ta' l-impjegati. Ikseb in-numru ta 'dipartimenti li għandhom impjegati
deċiżjoni

SELECT COUNT (COUNT (*))     department_count
    FROM employees
   WHERE department_id IS NOT NULL
GROUP BY department_id;

Tabella ta' l-impjegati. Ikseb lista ta' department_ids li għandhom aktar minn 30 impjegat
deċiżjoni

  SELECT department_id
    FROM employees
GROUP BY department_id
  HAVING COUNT (*) > 30;

Tabella ta' l-impjegati. Ikseb lista ta' department_ids u s-salarju medju arrotondat tal-impjegati f'kull dipartiment.
deċiżjoni

  SELECT department_id, ROUND (AVG (salary)) avg_salary
    FROM employees
GROUP BY department_id;

Tabella Pajjiżi. Ikseb il-lista region_id is-somma tal-ittri kollha tal-ismijiet tal-pajjiżi kollha li fihom hemm aktar minn 60
deċiżjoni

  SELECT region_id
    FROM countries
GROUP BY region_id
  HAVING SUM (LENGTH (country_name)) > 60;

Tabella ta' l-impjegati. Ikseb lista ta' department_ids li fihom jaħdmu impjegati ta' diversi (>1) job_ids
deċiżjoni

  SELECT department_id
    FROM employees
GROUP BY department_id
  HAVING COUNT (DISTINCT job_id) > 1;

Tabella ta' l-impjegati. Ikseb lista ta' manager_ids li n-numru ta' subordinati tagħhom huwa akbar minn 5 u s-somma tas-salarji kollha tas-subordinati tiegħu hija akbar minn 50000
deċiżjoni

  SELECT manager_id
    FROM employees
GROUP BY manager_id
  HAVING COUNT (*) > 5 AND SUM (salary) > 50000;

Tabella ta' l-impjegati. Ikseb lista ta 'manager_ids li s-salarju medju tagħhom tas-subordinati kollha tiegħu huwa fil-medda minn 6000 sa 9000 u li ma jirċevux bonuses (commission_pct hija vojta)
deċiżjoni

  SELECT manager_id, AVG (salary) avg_salary
    FROM employees
   WHERE commission_pct IS NULL
GROUP BY manager_id
  HAVING AVG (salary) BETWEEN 6000 AND 9000;

Tabella ta' l-impjegati. Ikseb is-salarju massimu mill-impjegati kollha job_id li jispiċċa bil-kelma 'CLERK'
deċiżjoni

SELECT MAX (salary) max_salary
  FROM employees
 WHERE job_id LIKE '%CLERK';

SELECT MAX (salary) max_salary
  FROM employees
 WHERE SUBSTR (job_id, -5) = 'CLERK';

Tabella ta' l-impjegati. Ikseb is-salarju massimu fost is-salarji medji kollha għad-dipartiment
deċiżjoni

  SELECT MAX (AVG (salary))
    FROM employees
GROUP BY department_id;

Tabella ta' l-impjegati. Ikseb in-numru ta' impjegati bl-istess numru ta' ittri f'isimhom. Fl-istess ħin, uri biss dawk li t-tul tal-isem tagħhom huwa aktar minn 5 u n-numru ta’ impjegati bl-istess isem huwa aktar minn 20. Issortja skont it-tul tal-isem
deċiżjoni

  SELECT LENGTH (first_name), COUNT (*)
    FROM employees
GROUP BY LENGTH (first_name)
  HAVING LENGTH (first_name) > 5 AND COUNT (*) > 20
ORDER BY LENGTH (first_name);

  SELECT LENGTH (first_name), COUNT (*)
    FROM employees
   WHERE LENGTH (first_name) > 5
GROUP BY LENGTH (first_name)
  HAVING COUNT (*) > 20
ORDER BY LENGTH (first_name);

Wiri Dejta minn Tabelli Multipli Bl-użu ta' Joins

Tabella Impjegati, Dipartimenti, Postijiet, Pajjiżi, Reġjuni. Ikseb lista ta 'reġjuni u n-numru ta' impjegati f'kull reġjun
deċiżjoni

  SELECT region_name, COUNT (*)
    FROM employees e
         JOIN departments d ON (e.department_id = d.department_id)
         JOIN locations l ON (d.location_id = l.location_id)
         JOIN countries c ON (l.country_id = c.country_id)
         JOIN regions r ON (c.region_id = r.region_id)
GROUP BY region_name;

Tabella Impjegati, Dipartimenti, Postijiet, Pajjiżi, Reġjuni. Ikseb informazzjoni dettaljata dwar kull impjegat:
Isem, Kunjom, Dipartiment, Impjieg, Triq, Pajjiż, Reġjun
deċiżjoni

SELECT First_name,
       Last_name,
       Department_name,
       Job_id,
       street_address,
       Country_name,
       Region_name
  FROM employees  e
       JOIN departments d ON (e.department_id = d.department_id)
       JOIN locations l ON (d.location_id = l.location_id)
       JOIN countries c ON (l.country_id = c.country_id)
       JOIN regions r ON (c.region_id = r.region_id);

Tabella ta' l-impjegati. Uri l-maniġers kollha li għandhom aktar minn 6 impjegati subordinati għalihom
deċiżjoni

  SELECT man.first_name, COUNT (*)
    FROM employees emp JOIN employees man ON (emp.manager_id = man.employee_id)
GROUP BY man.first_name
  HAVING COUNT (*) > 6;

Tabella ta' l-impjegati. Uri l-impjegati kollha li ma jirrappurtaw lil ħadd
deċiżjoni

SELECT emp.first_name
  FROM employees  emp
       LEFT JOIN employees man ON (emp.manager_id = man.employee_id)
 WHERE man.FIRST_NAME IS NULL;

SELECT first_name
  FROM employees
 WHERE manager_id IS NULL;

Tabella Impjegati, Job_history. It-tabella tal-Impjegati taħżen l-impjegati kollha. It-tabella Job_history taħżen l-impjegati li telqu mill-kumpanija. Ikseb rapport dwar l-impjegati kollha u l-istatus tagħhom fil-kumpanija (Taħdem jew ħalliet il-kumpanija bid-data tat-tluq)
Eżempju:
l-isem | status
Jennifer | Ħalliet il-kumpanija fil-31 ta’ Diċembru, 2006
Clara | Bħalissa qed taħdem
deċiżjoni

SELECT first_name,
       NVL2 (
           end_date,
           TO_CHAR (end_date, 'fm""Left the company at"" DD ""of"" Month, YYYY'),
           'Currently Working')
           status
  FROM employees e LEFT JOIN job_history j ON (e.employee_id = j.employee_id);

Tabella Impjegati, Dipartimenti, Postijiet, Pajjiżi, Reġjuni. Ikseb lista ta' impjegati li jgħixu fl-Ewropa (region_name)
deċiżjoni

 SELECT first_name
  FROM employees
       JOIN departments USING (department_id)
       JOIN locations USING (location_id)
       JOIN countries USING (country_id)
       JOIN regions USING (region_id)
 WHERE region_name = 'Europe';
 
 SELECT first_name
  FROM employees  e
       JOIN departments d ON (e.department_id = d.department_id)
       JOIN locations l ON (d.location_id = l.location_id)
       JOIN countries c ON (l.country_id = c.country_id)
       JOIN regions r ON (c.region_id = r.region_id)
 WHERE region_name = 'Europe';

Tabella Impjegati, Dipartimenti. Uri d-dipartimenti kollha b'aktar minn 30 impjegat
deċiżjoni

SELECT department_name, COUNT (*)
    FROM employees e JOIN departments d ON (e.department_id = d.department_id)
GROUP BY department_name
  HAVING COUNT (*) > 30;

Tabella Impjegati, Dipartimenti. Uri l-impjegati kollha li mhumiex fl-ebda dipartiment
deċiżjoni

SELECT first_name
  FROM employees  e
       LEFT JOIN departments d ON (e.department_id = d.department_id)
 WHERE d.department_name IS NULL;

SELECT first_name
  FROM employees
 WHERE department_id IS NULL;

Tabella Impjegati, Dipartimenti. Uri d-dipartimenti kollha li fihom m'hemmx impjegati
deċiżjoni

SELECT department_name
  FROM employees  e
       RIGHT JOIN departments d ON (e.department_id = d.department_id)
 WHERE first_name IS NULL;

Tabella ta' l-impjegati. Uri l-impjegati kollha li m'għandhom lil ħadd subordinat għalihom
deċiżjoni

SELECT man.first_name
  FROM employees  emp
       RIGHT JOIN employees man ON (emp.manager_id = man.employee_id)
 WHERE emp.FIRST_NAME IS NULL;

Tabella Impjegati, Impjiegi, Dipartimenti. Uri l-impjegati fil-format: First_name, Job_title, Department_name.
Eżempju:
L-isem | Job_title | isem_dipartiment
Donald | Trasport bil-baħar | Skrivan tat-Tbaħħir
deċiżjoni

SELECT first_name, job_title, department_name
  FROM employees  e
       JOIN jobs j ON (e.job_id = j.job_id)
       JOIN departments d ON (d.department_id = e.department_id);

Tabella ta' l-impjegati. Ikseb lista ta' impjegati li l-maniġers tagħhom kisbu impjieg fl-2005, iżda fl-istess ħin dawn l-impjegati nfushom kisbu impjieg qabel l-2005
deċiżjoni

SELECT emp.*
  FROM employees emp JOIN employees man ON (emp.manager_id = man.employee_id)
 WHERE     TO_CHAR (man.hire_date, 'YYYY') = '2005'
       AND emp.hire_date < TO_DATE ('01012005', 'DDMMYYYY');

Tabella ta' l-impjegati. Ikseb lista ta' impjegati li l-maniġers tagħhom kisbu impjieg f'Jannar ta' kull sena u t-tul job_title ta' dawn l-impjegati huwa ta' aktar minn 15-il karattru
deċiżjoni

SELECT emp.*
  FROM employees  emp
       JOIN employees man ON (emp.manager_id = man.employee_id)
       JOIN jobs j ON (emp.job_id = j.job_id)
 WHERE TO_CHAR (man.hire_date, 'MM') = '01' AND LENGTH (j.job_title) > 15;

Uża Subqueries biex Issolvi Mistoqsijiet

Tabella ta' l-impjegati. Ikseb lista ta' impjegati bl-itwal isem.
deċiżjoni

SELECT *
  FROM employees
 WHERE LENGTH (first_name) =
       (SELECT MAX (LENGTH (first_name)) FROM employees);

Tabella ta' l-impjegati. Ikseb lista ta 'impjegati b'salarju akbar mis-salarju medju tal-impjegati kollha.
deċiżjoni

SELECT *
  FROM employees
 WHERE salary > (SELECT AVG (salary) FROM employees);

Impjegati, Dipartimenti, tabella tal-Lokazzjonijiet. Ikseb il-belt li fiha l-impjegati b'kollox jaqilgħu l-inqas.
deċiżjoni

SELECT city
    FROM employees e
         JOIN departments d ON (e.department_id = d.department_id)
         JOIN locations l ON (d.location_id = l.location_id)
GROUP BY city
  HAVING SUM (salary) =
         (  SELECT MIN (SUM (salary))
              FROM employees e
                   JOIN departments d ON (e.department_id = d.department_id)
                   JOIN locations l ON (d.location_id = l.location_id)
          GROUP BY city);

Tabella ta' l-impjegati. Ikseb lista ta 'impjegati li l-maniġer tagħhom jirċievi salarju ta' aktar minn 15000.
deċiżjoni

SELECT *
  FROM employees
 WHERE manager_id IN (SELECT employee_id
                        FROM employees
                       WHERE salary > 15000)

Tabella Impjegati, Dipartimenti. Uri d-dipartimenti kollha li fihom m'hemmx impjegati
deċiżjoni

SELECT *
  FROM departments
 WHERE department_id NOT IN (SELECT department_id
                               FROM employees
                              WHERE department_id IS NOT NULL);

Tabella ta' l-impjegati. Uri l-impjegati kollha li mhumiex maniġers
deċiżjoni

SELECT *
  FROM employees
 WHERE employee_id NOT IN (SELECT manager_id
                             FROM employees
                            WHERE manager_id IS NOT NULL)

Tabella ta' l-impjegati. Uri l-maniġers kollha li għandhom aktar minn 6 impjegati subordinati għalihom
deċiżjoni

SELECT *
  FROM employees e
 WHERE (SELECT COUNT (*)
          FROM employees
         WHERE manager_id = e.employee_id) > 6;

Tabella Impjegati, Dipartimenti. Uri l-impjegati li jaħdmu fid-dipartiment tal-IT
deċiżjoni

SELECT *
  FROM employees
 WHERE department_id = (SELECT department_id
                          FROM departments
                         WHERE department_name = 'IT');

Tabella Impjegati, Impjiegi, Dipartimenti. Uri l-impjegati fil-format: First_name, Job_title, Department_name.
Eżempju:
L-isem | Job_title | isem_dipartiment
Donald | Trasport bil-baħar | Skrivan tat-Tbaħħir
deċiżjoni

SELECT first_name,
       (SELECT job_title
          FROM jobs
         WHERE job_id = e.job_id)
           job_title,
       (SELECT department_name
          FROM departments
         WHERE department_id = e.department_id)
           department_name
  FROM employees e;

Tabella ta' l-impjegati. Ikseb lista ta' impjegati li l-maniġers tagħhom kisbu impjieg fl-2005, iżda fl-istess ħin dawn l-impjegati nfushom kisbu impjieg qabel l-2005
deċiżjoni

SELECT *
  FROM employees
 WHERE     manager_id IN (SELECT employee_id
                            FROM employees
                           WHERE TO_CHAR (hire_date, 'YYYY') = '2005')
       AND hire_date < TO_DATE ('01012005', 'DDMMYYYY');

Tabella ta' l-impjegati. Ikseb lista ta' impjegati li l-maniġers tagħhom kisbu impjieg f'Jannar ta' kull sena u t-tul job_title ta' dawn l-impjegati huwa ta' aktar minn 15-il karattru
deċiżjoni

SELECT *
  FROM employees e
 WHERE     manager_id IN (SELECT employee_id
                            FROM employees
                           WHERE TO_CHAR (hire_date, 'MM') = '01')
       AND (SELECT LENGTH (job_title)
              FROM jobs
             WHERE job_id = e.job_id) > 15;

Dak kollu għalissa.

Nittama li l-kompiti kienu interessanti u eċċitanti.
Se nżid ma' din il-lista ta' kompiti kemm jista' jkun.
Inkun kuntent ukoll li nirċievi xi kummenti u suġġerimenti.

PS: Jekk xi ħadd joħroġ b'biċċa xogħol SELECT interessanti, ikteb fil-kummenti u nżidha mal-lista.

Grazzi.

Sors: www.habr.com

Żid kumment