เอสคิวแอล ปริศนาที่สนุกสนาน

สวัสดีฮับ!

เป็นเวลากว่า 3 ปีที่ฉันสอน SQL ในศูนย์ฝึกอบรมต่างๆ และข้อสังเกตอย่างหนึ่งของฉันคือนักเรียนจะเชี่ยวชาญและเข้าใจ SQL ได้ดีขึ้นหากได้รับงาน ไม่ใช่เพียงแค่พูดคุยเกี่ยวกับความเป็นไปได้และพื้นฐานทางทฤษฎีเท่านั้น

ในบทความนี้ ฉันจะแบ่งปันรายการงานที่ฉันให้นักเรียนเป็นการบ้านและที่เราทำการระดมสมองประเภทต่างๆ ซึ่งนำไปสู่ความเข้าใจที่ลึกซึ้งและชัดเจนของ SQL

เอสคิวแอล ปริศนาที่สนุกสนาน

SQL (ˈɛsˈkjuˈɛl; eng. ภาษาคิวรีที่มีโครงสร้าง) เป็นภาษาโปรแกรมเชิงประกาศที่ใช้เพื่อสร้าง แก้ไข และจัดการข้อมูลในฐานข้อมูลเชิงสัมพันธ์ที่จัดการโดยระบบจัดการฐานข้อมูลที่เหมาะสม เรียนรู้เพิ่มเติม

คุณสามารถอ่านเกี่ยวกับ SQL ได้จากที่ต่างๆ แหล่งที่มา.
บทความนี้ไม่ได้มีวัตถุประสงค์เพื่อสอน SQL ให้คุณตั้งแต่เริ่มต้น

งั้นไปกันเถอะ

เราจะใช้ที่รู้จักกันดี โครงการทรัพยากรบุคคล ใน Oracle พร้อมตาราง (ขึ้น):

เอสคิวแอล ปริศนาที่สนุกสนาน
ฉันทราบว่าเราจะพิจารณาเฉพาะงานใน SELECT ไม่มีงานใน DML และ DDL

งาน

การจำกัดและจัดเรียงข้อมูล

โต๊ะพนักงาน. รับรายชื่อพร้อมข้อมูลเกี่ยวกับพนักงานทั้งหมด
การตัดสิน

SELECT * FROM employees

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่ชื่อ 'David'
การตัดสิน

SELECT *
  FROM employees
 WHERE first_name = 'David';

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มี job_id เท่ากับ 'IT_PROG'
การตัดสิน

SELECT *
  FROM employees
 WHERE job_id = 'IT_PROG'

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดจากแผนกที่ 50 (department_id) ที่มีเงินเดือน (เงินเดือน) มากกว่า 4000
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดจากแผนกที่ 20 และจากแผนกที่ 30 (department_id)
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีอักษรตัวสุดท้ายในชื่อ 'a'
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดจากแผนกที่ 50 และจากแผนกที่ 80 (department_id) ที่มีโบนัส (ค่าในคอลัมน์ commission_pct ไม่ว่างเปล่า)
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีตัวอักษร 'n' อย่างน้อย 2 ตัวในชื่อ
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีชื่อยาวกว่า 4 ตัวอักษร
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีเงินเดือนระหว่าง 8000 ถึง 9000 (รวม)
การตัดสิน

SELECT *
  FROM employees
 WHERE salary BETWEEN 8000 AND 9000;

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีสัญลักษณ์ '%'
การตัดสิน

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

โต๊ะพนักงาน. รับรายการรหัสผู้จัดการทั้งหมด
การตัดสิน

SELECT DISTINCT manager_id
  FROM employees
 WHERE manager_id IS NOT NULL;

โต๊ะพนักงาน. รับรายชื่อพนักงานพร้อมตำแหน่งในรูปแบบ: Donald(sh_clerk)
การตัดสิน

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

การใช้ฟังก์ชันแถวเดียวเพื่อปรับแต่งเอาต์พุต

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีชื่อยาวกว่า 10 ตัวอักษร
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีตัวอักษร 'b' อยู่ในชื่อ (โดยไม่คำนึงถึงตัวพิมพ์เล็กและใหญ่)
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีตัวอักษร 'a' อย่างน้อย 2 ตัว
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีเงินเดือนหลายเท่าของ 1000
การตัดสิน

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

โต๊ะพนักงาน. รับหมายเลขโทรศัพท์ 3 หลักแรกของพนักงาน หากหมายเลขของเขาอยู่ในรูปแบบ ХХХ.ХХХ.ХХХХ
การตัดสิน

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

ตารางแผนก. รับคำแรกจากชื่อแผนกสำหรับผู้ที่มีมากกว่าหนึ่งคำในชื่อ
การตัดสิน

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

โต๊ะพนักงาน. รับชื่อพนักงานโดยไม่มีอักษรตัวแรกและตัวสุดท้ายในชื่อ
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีตัวอักษรตัวสุดท้ายในชื่อเท่ากับ 'm' และความยาวของชื่อมากกว่า 5
การตัดสิน

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

โต๊ะคู่. รับวันที่ของวันศุกร์หน้า
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทุกคนที่อยู่กับบริษัทมานานกว่า 17 ปี
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีหมายเลขโทรศัพท์หลักสุดท้ายเป็นเลขคี่และประกอบด้วยตัวเลข 3 ตัวคั่นด้วยจุด
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีค่า job_id หลังเครื่องหมาย '_' อย่างน้อย 3 อักขระ แต่ค่านี้หลัง '_' ไม่เท่ากับ 'CLERK'
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดโดยแทนที่ '.' ทั้งหมดในค่า PHONE_NUMBER บน '-'
การตัดสิน

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

การใช้ฟังก์ชันการแปลงและนิพจน์ตามเงื่อนไข

โต๊ะพนักงาน. ขอรายชื่อพนักงานที่มาทำงานวันแรกของเดือน (ใดๆ)
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่เข้ามาทำงานในปี 2008
การตัดสิน

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

ตารางคู่ แสดงวันที่ของวันพรุ่งนี้ในรูปแบบ: พรุ่งนี้คือวันที่สองของเดือนมกราคม
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดและวันที่เริ่มทำงานในรูปแบบ: 21 มิถุนายน 2007
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานที่มีเงินเดือนเพิ่มขึ้น 20% แสดงเงินเดือนด้วยเครื่องหมายดอลลาร์
การตัดสิน

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

โต๊ะพนักงาน. รายชื่อพนักงานที่เข้ามาทำงานในเดือน กุมภาพันธ์ 2007
การตัดสิน

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

ตารางคู่ ส่งออกวันที่ปัจจุบัน + วินาที + นาที + ชั่วโมง + วัน + เดือน + ปี
การตัดสิน

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;

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดที่มีเงินเดือนเต็มจำนวน (เงินเดือน + ค่าคอมมิชชั่น_pct(%)) ในรูปแบบ: $24,000.00
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานทั้งหมดและข้อมูลเกี่ยวกับความพร้อมของโบนัสเงินเดือน (ใช่/ไม่ใช่)
การตัดสิน

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

โต๊ะพนักงาน. รับระดับเงินเดือนของพนักงานแต่ละคน: น้อยกว่า 5000 ถือเป็นระดับต่ำ, มากกว่าหรือเท่ากับ 5000 และน้อยกว่า 10000 ถือเป็นระดับปกติ, มากกว่าหรือเท่ากับ 10000 ถือเป็นระดับสูง
การตัดสิน

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;

ตารางประเทศ สำหรับแต่ละประเทศ แสดงภูมิภาคที่ตั้งอยู่: 1-ยุโรป 2-อเมริกา 3-เอเชีย 4-แอฟริกา (โดยไม่ต้องเข้าร่วม)
การตัดสิน

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;

การรายงานข้อมูลที่รวบรวมโดยใช้ฟังก์ชันกลุ่ม

โต๊ะพนักงาน. รับรายงานตาม department_id พร้อมเงินเดือนขั้นต่ำและสูงสุด วันที่มาถึงก่อนกำหนดและล่าช้า และจำนวนพนักงาน เรียงตามจำนวนพนักงาน (desc)
การตัดสิน

  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;

โต๊ะพนักงาน. ชื่อขึ้นต้นด้วยตัวอักษรเดียวกันมีพนักงานกี่คน? จัดเรียงตามปริมาณ แสดงเฉพาะตัวเลขที่มากกว่า 1
การตัดสิน

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;

โต๊ะพนักงาน. มีพนักงานกี่คนที่ทำงานในแผนกเดียวกันและได้รับเงินเดือนเท่ากัน?
การตัดสิน

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

โต๊ะพนักงาน. รับรายงานจำนวนพนักงานที่ได้รับการว่าจ้างในแต่ละวันของสัปดาห์ จัดเรียงตามปริมาณ
การตัดสิน

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

โต๊ะพนักงาน. รับรายงานเกี่ยวกับจำนวนพนักงานที่ได้รับการว่าจ้างในแต่ละปี จัดเรียงตามปริมาณ
การตัดสิน

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

โต๊ะพนักงาน. รับจำนวนแผนกที่มีพนักงาน
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อ department_id ที่มีพนักงานมากกว่า 30 คน
การตัดสิน

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

โต๊ะพนักงาน. รับรายการ department_ids และเงินเดือนเฉลี่ยแบบปัดเศษของพนักงานในแต่ละแผนก
การตัดสิน

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

ตารางประเทศ รับรายการผลรวมของ Region_id ของตัวอักษรทั้งหมดของชื่อประเทศทั้งหมดที่มากกว่า 60
การตัดสิน

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

โต๊ะพนักงาน. รับรายการ department_id ที่พนักงานของ job_id หลาย (>1) คนทำงาน
การตัดสิน

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

โต๊ะพนักงาน. รับรายการ manager_id ที่มีจำนวนผู้ใต้บังคับบัญชามากกว่า 5 คน และผลรวมของเงินเดือนทั้งหมดของผู้ใต้บังคับบัญชามากกว่า 50000
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อ manager_id ซึ่งเงินเดือนเฉลี่ยของผู้ใต้บังคับบัญชาทั้งหมดอยู่ระหว่าง 6000 ถึง 9000 ที่ไม่ได้รับโบนัส (commission_pct ว่างเปล่า)
การตัดสิน

  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;

โต๊ะพนักงาน. รับเงินเดือนสูงสุดจากพนักงานทุกคนที่ job_id ที่ลงท้ายด้วยคำว่า 'CLERK'
การตัดสิน

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

โต๊ะพนักงาน. รับเงินเดือนสูงสุดจากเงินเดือนเฉลี่ยทั้งหมดสำหรับแผนก
การตัดสิน

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

โต๊ะพนักงาน. รับจำนวนพนักงานที่มีจำนวนตัวอักษรเท่ากันในชื่อ ในขณะเดียวกันให้แสดงเฉพาะผู้ที่มีชื่อยาวเกิน 5 คน และจำนวนพนักงานที่มีชื่อเดียวกันมากกว่า 20 คน เรียงตามความยาวชื่อ
การตัดสิน

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

การแสดงข้อมูลจากหลายตารางโดยใช้การรวม

พนักงานประจำโต๊ะ แผนก สถานที่ ประเทศ ภูมิภาค รับรายชื่อภูมิภาคและจำนวนพนักงานในแต่ละภูมิภาค
การตัดสิน

  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;

พนักงานประจำโต๊ะ แผนก สถานที่ ประเทศ ภูมิภาค รับข้อมูลโดยละเอียดเกี่ยวกับพนักงานแต่ละคน:
First_name, Last_name, Department, Job, Street, Country, Region
การตัดสิน

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

โต๊ะพนักงาน. แสดงผู้จัดการทั้งหมดที่มีพนักงานมากกว่า 6 คน
การตัดสิน

  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;

โต๊ะพนักงาน. แสดงพนักงานทั้งหมดที่ไม่รายงานต่อใคร
การตัดสิน

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;

ตารางพนักงาน, Job_history. ตารางพนักงานจัดเก็บพนักงานทั้งหมด ตาราง Job_history เก็บพนักงานที่ลาออกจากบริษัท รับรายงานเกี่ยวกับพนักงานทุกคนและสถานะของพวกเขาในบริษัท (จ้างหรือออกจากบริษัทพร้อมวันที่ออกจากงาน)
ตัวอย่าง:
ชื่อแรก | สถานะ
เจนนิเฟอร์ | ออกจากบริษัทเมื่อวันที่ 31 ธันวาคม 2006
คลาร่า | กำลังทำงานอยู่
การตัดสิน

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

พนักงานประจำโต๊ะ แผนก สถานที่ ประเทศ ภูมิภาค รับรายชื่อพนักงานที่อาศัยอยู่ในยุโรป (region_name)
การตัดสิน

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

พนักงานโต๊ะแผนก. แสดงแผนกทั้งหมดที่มีพนักงานมากกว่า 30 คน
การตัดสิน

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

พนักงานโต๊ะแผนก. แสดงพนักงานทั้งหมดที่ไม่ได้อยู่ในแผนกใด
การตัดสิน

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;

พนักงานโต๊ะแผนก. แสดงแผนกทั้งหมดที่ไม่มีพนักงาน
การตัดสิน

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

โต๊ะพนักงาน. แสดงพนักงานทั้งหมดที่ไม่มีผู้ใต้บังคับบัญชา
การตัดสิน

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

พนักงานตาราง งาน แผนก แสดงพนักงานในรูปแบบ: First_name, Job_title, Department_name
ตัวอย่าง:
ชื่อแรก | ชื่องาน | ชื่อห้างสรรพสินค้า
โดนัลด์ | การจัดส่งสินค้า | เสมียนชิปปิ้ง
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานที่ผู้จัดการได้งานในปี 2005 แต่ในเวลาเดียวกัน คนงานเหล่านี้เองก็ได้งานก่อนปี 2005
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานที่ผู้จัดการได้งานในเดือนมกราคมของปีใดๆ และความยาวของ job_title ของพนักงานเหล่านี้มีความยาวมากกว่า 15 ตัวอักษร
การตัดสิน

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;

การใช้แบบสอบถามย่อยเพื่อแก้ไขแบบสอบถาม

โต๊ะพนักงาน. รับรายชื่อพนักงานที่มีชื่อยาวที่สุด
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานที่มีเงินเดือนมากกว่าเงินเดือนเฉลี่ยของพนักงานทั้งหมด
การตัดสิน

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

พนักงานโต๊ะแผนกสถานที่ รับเมืองที่พนักงานมีรายได้รวมน้อยที่สุด
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานที่ผู้จัดการได้รับเงินเดือนมากกว่า 15000
การตัดสิน

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

พนักงานโต๊ะแผนก. แสดงแผนกทั้งหมดที่ไม่มีพนักงาน
การตัดสิน

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

โต๊ะพนักงาน. แสดงพนักงานทั้งหมดที่ไม่ใช่ผู้จัดการ
การตัดสิน

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

โต๊ะพนักงาน. แสดงผู้จัดการทั้งหมดที่มีพนักงานมากกว่า 6 คน
การตัดสิน

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

พนักงานโต๊ะแผนก. แสดงพนักงานที่ทำงานในแผนกไอที
การตัดสิน

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

พนักงานตาราง งาน แผนก แสดงพนักงานในรูปแบบ: First_name, Job_title, Department_name
ตัวอย่าง:
ชื่อแรก | ชื่องาน | ชื่อห้างสรรพสินค้า
โดนัลด์ | การจัดส่งสินค้า | เสมียนชิปปิ้ง
การตัดสิน

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;

โต๊ะพนักงาน. รับรายชื่อพนักงานที่ผู้จัดการได้งานในปี 2005 แต่ในเวลาเดียวกัน คนงานเหล่านี้เองก็ได้งานก่อนปี 2005
การตัดสิน

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

โต๊ะพนักงาน. รับรายชื่อพนักงานที่ผู้จัดการได้งานในเดือนมกราคมของปีใดๆ และความยาวของ job_title ของพนักงานเหล่านี้มีความยาวมากกว่า 15 ตัวอักษร
การตัดสิน

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;

นั่นคือทั้งหมดที่สำหรับตอนนี้.

ฉันหวังว่างานจะน่าสนใจและน่าตื่นเต้น
ฉันจะเพิ่มในรายการนี้ให้มากที่สุด
ฉันยินดีที่จะแสดงความคิดเห็นและข้อเสนอแนะ

PS: ถ้ามีคนเสนองานที่น่าสนใจเกี่ยวกับ SELECT เขียนความคิดเห็น ฉันจะเพิ่มลงในรายการ

ขอบคุณ

ที่มา: will.com

เพิ่มความคิดเห็น