SQL. Posau difyr

Helo Habr!

Am fwy na 3 blynedd rwyf wedi bod yn addysgu SQL mewn amrywiol ganolfannau hyfforddi, ac un o fy arsylwadau yw bod myfyrwyr yn meistroli ac yn deall SQL yn well os rhoddir tasg iddynt, ac nid dim ond siarad am y posibiliadau a'r sylfeini damcaniaethol.

Yn yr erthygl hon, byddaf yn rhannu gyda chi fy rhestr o dasgau yr wyf yn eu rhoi i fyfyrwyr fel gwaith cartref ac yr ydym yn cynnal gwahanol fathau o sesiynau taflu syniadau arnynt, sy'n arwain at ddealltwriaeth ddofn a chlir o SQL.

SQL. Posau difyr

Mae SQL (ˈɛsˈkjuˈɛl; eng. iaith ymholiad strwythuredig) yn iaith raglennu ddatganiadol a ddefnyddir i greu, addasu a rheoli data mewn cronfa ddata berthynol a reolir gan system rheoli cronfa ddata briodol. Darllen mwy…

Gallwch ddarllen am SQL o wahanol ffynonellau.
Nid bwriad yr erthygl hon yw dysgu SQL i chi o'r dechrau.

Felly gadewch i ni fynd.

Byddwn yn defnyddio'r adnabyddus Cynllun AD yn Oracle gyda'i fyrddau (Mwy):

SQL. Posau difyr
Sylwaf y byddwn yn ystyried tasgau ar SELECT yn unig. Nid oes unrhyw dasgau ar DML a DDL.

tasgau

Cyfyngu a Didoli Data

Bwrdd gweithwyr. Cael rhestr gyda gwybodaeth am yr holl weithwyr
penderfyniad

SELECT * FROM employees

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr o'r enw 'David'
penderfyniad

SELECT *
  FROM employees
 WHERE first_name = 'David';

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr gyda job_id sy'n cyfateb i 'IT_PROG'
penderfyniad

SELECT *
  FROM employees
 WHERE job_id = 'IT_PROG'

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr o'r 50fed adran (department_id) gyda chyflog (cyflog) yn fwy na 4000
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr o'r 20fed ac o'r 30ain adran (department_id)
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr y mae eu llythyren olaf yn eu henw yn 'a'
penderfyniad

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

Bwrdd gweithwyr. Sicrhewch restr o'r holl weithwyr o'r 50fed ac o'r 80fed adran (department_id) sydd â bonws (nid yw'r gwerth yn y golofn commission_pct yn wag)
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr y mae eu henw yn cynnwys o leiaf 2 lythyren 'n'
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o'r holl weithwyr y mae eu henw yn hwy na 4 llythyren
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr y mae eu cyflog rhwng 8000 a 9000 (yn gynwysedig)
penderfyniad

SELECT *
  FROM employees
 WHERE salary BETWEEN 8000 AND 9000;

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr y mae eu henw yn cynnwys y symbol '%'
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o holl IDs rheolwr
penderfyniad

SELECT DISTINCT manager_id
  FROM employees
 WHERE manager_id IS NOT NULL;

Bwrdd gweithwyr. Cael rhestr o weithwyr gyda'u swyddi yn y fformat: Donald(sh_clerk)
penderfyniad

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

Defnyddio Swyddogaethau Rhes Sengl i Addasu Allbwn

Bwrdd gweithwyr. Mynnwch restr o'r holl weithwyr y mae eu henw yn hwy na 10 llythyren
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o’r holl weithwyr sydd â’r llythyren ‘b’ yn eu henw (achos ansensitif)
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr y mae eu henw yn cynnwys o leiaf 2 lythyren 'a'
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o'r holl weithwyr y mae eu cyflog yn lluosrif o 1000
penderfyniad

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

Bwrdd gweithwyr. Sicrhewch rif 3 digid cyntaf rhif ffôn y cyflogai os yw ei rif yn y fformat ХХХ.ХХХ.ХХХХ
penderfyniad

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

Tabl adrannau. Cael y gair cyntaf o enw'r adran ar gyfer y rhai sydd â mwy nag un gair yn yr enw
penderfyniad

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

Bwrdd gweithwyr. Sicrhewch enwau gweithwyr heb y llythyren gyntaf ac olaf yn yr enw
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr y mae eu llythyren olaf yn yr enw yn hafal i 'm' ac mae hyd yr enw yn fwy na 5
penderfyniad

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

Bwrdd deuol. Cael y dyddiad dydd Gwener nesaf
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o'r holl weithwyr sydd wedi bod gyda'r cwmni ers dros 17 mlynedd
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr y mae eu digid olaf o'r rhif ffôn yn odrif ac yn cynnwys 3 rhif wedi'u gwahanu gan ddot
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr y mae gan eu gwerth job_id ar ôl yr arwydd '_' o leiaf 3 nod, ond nid yw'r gwerth hwn ar ôl y '_' yn hafal i 'CLERK'
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr drwy amnewid pob un '.' yn y gwerth PHONE_NUMBER ar '-'
penderfyniad

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

Defnyddio Swyddogaethau Trosi a Mynegiadau Amodol

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr a ddaeth i'r gwaith ar ddiwrnod cyntaf y mis (unrhyw un)
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o'r holl weithwyr a ddaeth i weithio yn 2008
penderfyniad

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

bwrdd DUW. Dangoswch ddyddiad yfory yn y fformat: Yfory yw Ail ddiwrnod Ionawr
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o'r holl weithwyr a'u dyddiad cychwyn yn y fformat: 21 Mehefin, 2007
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o weithwyr gyda chyflogau uwch o 20%. Dangoswch gyflog gydag arwydd doler
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o'r holl weithwyr a ddaeth i weithio ym mis Chwefror 2007.
penderfyniad

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'; 

bwrdd DUW. Allforio dyddiad cyfredol, + eiliad, + munud, + awr, + diwrnod, + mis, + blwyddyn
penderfyniad

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;

Bwrdd gweithwyr. Sicrhewch restr o'r holl weithwyr sydd â chyflogau llawn (cyflog + commission_pct(%)) yn y fformat: $24,000.00
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o'r holl weithwyr a gwybodaeth am argaeledd bonysau cyflog (Ie/Nac ydw)
penderfyniad

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

Bwrdd gweithwyr. Cael lefel cyflog pob gweithiwr: Ystyrir bod llai na 5000 yn lefel Isel, yn fwy na neu'n hafal i 5000 ac yn llai na 10000 yn cael ei ystyried Lefel arferol, yn fwy na neu'n hafal i 10000 yn cael ei ystyried yn lefel uchel.
penderfyniad

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;

Tabl gwledydd. Ar gyfer pob gwlad, dangoswch y rhanbarth y mae wedi'i leoli ynddo: 1-Ewrop, 2-America, 3-Asia, 4-Africa (heb Ymuno)
penderfyniad

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;

Adrodd ar Ddata Cyfunol gan Ddefnyddio Swyddogaethau'r Grŵp

Bwrdd gweithwyr. Cael adroddiad fesul adran_id gydag isafswm ac uchafswm cyflog, dyddiadau cyrraedd yn gynnar ac yn hwyr a nifer y gweithwyr. Trefnu yn ôl nifer y gweithwyr (desc)
penderfyniad

  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;

Bwrdd gweithwyr. Faint o weithwyr y mae eu henwau yn dechrau gyda'r un llythyren? Trefnu yn ôl maint. Dangoswch y rhai lle mae'r rhif yn fwy nag 1 yn unig
penderfyniad

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;

Bwrdd gweithwyr. Faint o weithwyr sy'n gweithio yn yr un adran ac yn derbyn yr un cyflog?
penderfyniad

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

Bwrdd gweithwyr. Mynnwch adroddiad o faint o weithwyr a gyflogwyd ar bob diwrnod o'r wythnos. Trefnu yn ôl maint
penderfyniad

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

Bwrdd gweithwyr. Mynnwch adroddiad ar faint o weithwyr a gyflogwyd fesul blwyddyn. Trefnu yn ôl maint
penderfyniad

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

Bwrdd gweithwyr. Mynnwch nifer yr adrannau sydd â gweithwyr
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o adran_id gyda mwy na 30 o weithwyr
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o adrannau_ids a chyflog cyfartalog crwn y gweithwyr ym mhob adran.
penderfyniad

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

Tabl gwledydd. Cael rhestr o rhanbarth_id swm holl lythrennau pob gwlad_enw gyda mwy na 60
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o adran_id lle mae gweithwyr sawl (> 1) job_id yn gweithio
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o manager_id y mae nifer ei is-weithwyr yn fwy na 5 a swm holl gyflogau ei is-weithwyr yn fwy na 50000
penderfyniad

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

Bwrdd gweithwyr. Mynnwch restr o manager_id y mae ei gyflog cyfartalog o'i holl is-weithwyr rhwng 6000 a 9000 nad ydynt yn derbyn taliadau bonws (commission_pct yn wag)
penderfyniad

  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;

Bwrdd gweithwyr. Cael yr uchafswm cyflog gan bob cyflogai job_id sy'n gorffen gyda'r gair 'CLERK'
penderfyniad

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';

Bwrdd gweithwyr. Sicrhewch yr uchafswm cyflog ymhlith holl gyflogau cyfartalog yr adran
penderfyniad

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

Bwrdd gweithwyr. Sicrhewch nifer y gweithwyr sydd â'r un nifer o lythrennau yn eu henw. Ar yr un pryd, dangoswch y rhai y mae eu henw yn hwy na 5 yn unig a nifer y gweithwyr gyda'r un enw yn fwy nag 20. Trefnwch yn ôl hyd enw
penderfyniad

  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);

Arddangos Data o Dablau Lluosog gan Ddefnyddio Uniadau

Gweithwyr Bwrdd, Adrannau, Lleoliadau, Gwledydd, Rhanbarthau. Cael rhestr o ranbarthau a nifer y gweithwyr ym mhob rhanbarth
penderfyniad

  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;

Gweithwyr Bwrdd, Adrannau, Lleoliadau, Gwledydd, Rhanbarthau. Cael gwybodaeth fanwl am bob gweithiwr:
Enw_cyntaf, Enw_olaf, Adran, Swydd, Stryd, Gwlad, Rhanbarth
penderfyniad

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);

Bwrdd gweithwyr. Dangoswch bob rheolwr sydd â mwy na 6 o weithwyr
penderfyniad

  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;

Bwrdd gweithwyr. Dangoswch yr holl weithwyr nad ydynt yn adrodd i unrhyw un
penderfyniad

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;

Bwrdd gweithwyr, Job_history. Mae bwrdd y Gweithwyr yn storio'r holl weithwyr. Mae'r tabl Job_history yn storio gweithwyr a adawodd y cwmni. Cael adroddiad ar yr holl weithwyr a'u statws yn y cwmni (Cyflogedig neu wedi gadael y cwmni gyda'r dyddiad gadael)
Enghraifft:
enw_cyntaf | statws
jennifer | Gadawodd y cwmni ar 31 Rhagfyr, 2006
Clara | Yn Gweithio ar hyn o bryd
penderfyniad

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);

Gweithwyr Bwrdd, Adrannau, Lleoliadau, Gwledydd, Rhanbarthau. Cael rhestr o weithwyr sy'n byw yn Ewrop (region_name)
penderfyniad

 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';

Gweithwyr Bwrdd, Adrannau. Dangoswch bob adran sydd â mwy na 30 o weithwyr
penderfyniad

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

Gweithwyr Bwrdd, Adrannau. Dangoswch yr holl weithwyr nad ydynt mewn unrhyw adran
penderfyniad

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;

Gweithwyr Bwrdd, Adrannau. Dangos pob adran heb unrhyw weithwyr
penderfyniad

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

Bwrdd gweithwyr. Dangoswch yr holl weithwyr sydd heb unrhyw is-weithwyr
penderfyniad

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

Gweithwyr Bwrdd, Swyddi, Adrannau. Dangos gweithwyr yn y fformat: Enw_cyntaf, Job_title, Department_name.
Enghraifft:
enw_cyntaf | teitl swydd | Enw_adran
Donald | llongau | Llongau Clerc
penderfyniad

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);

Bwrdd gweithwyr. Cael rhestr o weithwyr y cafodd eu rheolwyr swydd yn 2005, ond ar yr un pryd, cafodd y gweithwyr hyn eu hunain swydd cyn 2005
penderfyniad

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');

Bwrdd gweithwyr. Cael rhestr o weithwyr y cafodd eu rheolwyr swydd ym mis Ionawr unrhyw flwyddyn ac mae hyd teitl swydd y gweithwyr hyn yn fwy na 15 nod
penderfyniad

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;

Defnyddio Subqueries i Ddatrys Ymholiadau

Bwrdd gweithwyr. Cael rhestr o weithwyr gyda'r enw hiraf.
penderfyniad

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

Bwrdd gweithwyr. Cael rhestr o weithwyr gyda chyflog sy'n fwy na chyflog cyfartalog yr holl weithwyr.
penderfyniad

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

Gweithwyr Bwrdd, Adrannau, Lleoliadau. Sicrhewch y ddinas lle mae gweithwyr yn ennill y cyfanswm lleiaf.
penderfyniad

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);

Bwrdd gweithwyr. Mynnwch restr o weithwyr y mae eu rheolwr yn derbyn cyflog o fwy na 15000.
penderfyniad

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

Gweithwyr Bwrdd, Adrannau. Dangos pob adran heb unrhyw weithwyr
penderfyniad

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

Bwrdd gweithwyr. Dangoswch yr holl weithwyr nad ydynt yn rheolwyr
penderfyniad

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

Bwrdd gweithwyr. Dangoswch bob rheolwr sydd â mwy na 6 o weithwyr
penderfyniad

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

Gweithwyr Bwrdd, Adrannau. Dangoswch weithwyr sy'n gweithio yn yr adran TG
penderfyniad

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

Gweithwyr Bwrdd, Swyddi, Adrannau. Dangos gweithwyr yn y fformat: Enw_cyntaf, Job_title, Department_name.
Enghraifft:
enw_cyntaf | teitl swydd | Enw_adran
Donald | llongau | Llongau Clerc
penderfyniad

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;

Bwrdd gweithwyr. Cael rhestr o weithwyr y cafodd eu rheolwyr swydd yn 2005, ond ar yr un pryd, cafodd y gweithwyr hyn eu hunain swydd cyn 2005
penderfyniad

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');

Bwrdd gweithwyr. Cael rhestr o weithwyr y cafodd eu rheolwyr swydd ym mis Ionawr unrhyw flwyddyn ac mae hyd teitl swydd y gweithwyr hyn yn fwy na 15 nod
penderfyniad

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;

Dyna i gyd am y tro.

Gobeithio bod y tasgau wedi bod yn ddiddorol ac yn gyffrous.
Byddaf yn ychwanegu cymaint â phosibl at y rhestr hon.
Byddaf hefyd yn falch o gael unrhyw sylwadau ac awgrymiadau.

ON: Os bydd rhywun yn gwneud tasg ddiddorol ar SELECT, ysgrifennwch y sylwadau, byddaf yn ei ychwanegu at y rhestr.

Diolch yn fawr.

Ffynhonnell: hab.com

Ychwanegu sylw