[英]MySQL - Display null column from child table if all values are not distinct
[英]IS NULL not finding all null values in column MYSQL
UPDATE student as s
LEFT JOIN takes as t ON s.ID = t.ID
LEFT JOIN course as c ON t.course_id = c.course_id
SET s.tot_cred = s.tot_cred - COALESCE(c.credits, 0)
WHERE t.grade = 'F'
OR
t.grade IS NULL
我正在嘗試通過減去學生未通過的任何班級的學分值來更新學生的tot_cred,成績為“ F”或當前正在接受成績為IS NULL。
上面的查詢適用於“ takes”關系中的單個“ F”等級。 但是,它僅適用於成績列中“ takes”關系中的4個NULL值之一。
SQL很新,我覺得查詢中的某些內容只是在尋找第一個NULL值,而不是全部。
表格:
mysql> select ID, tot_cred
-> from student;
+-------+----------+
| ID | tot_cred |
+-------+----------+
| 00128 | 102 |
| 12345 | 32 |
| 19991 | 80 |
| 23121 | 110 |
| 44553 | 56 |
| 45678 | 38 |
| 54321 | 54 |
| 55739 | 38 |
| 70557 | 0 |
| 76543 | 58 |
| 76653 | 60 |
| 98765 | 98 |
| 98988 | 112 |
+-------+----------+
如果對應的成績是F或NULL,我想在這里更改tot_cred
mysql> select ID, course_id, grade
-> from takes
-> order by grade;
+-------+-----------+-------+
| ID | course_id | grade |
+-------+-----------+-------+
| 76543 | CS-001 | NULL |
| 54321 | CS-001 | NULL |
| 12345 | CS-001 | NULL |
| 98988 | BIO-301 | NULL |
| 98988 | BIO-101 | A |
| 76543 | CS-319 | A |
| 76543 | CS-101 | A |
| 00128 | CS-101 | A |
| 12345 | CS-190 | A |
| 12345 | CS-315 | A |
| 54321 | CS-101 | A- |
| 55739 | MU-199 | A- |
| 45678 | CS-319 | B |
| 19991 | HIS-351 | B |
| 98765 | CS-315 | B |
| 45678 | CS-101 | B+ |
| 54321 | CS-190 | B+ |
| 44553 | PHY-101 | B- |
| 12345 | CS-101 | C |
| 76653 | EE-181 | C |
| 23121 | FIN-201 | C+ |
| 98765 | CS-101 | C- |
| 45678 | CS-101 | F |
+-------+-----------+-------+
這是成績所在。 有4個NULL值和1F。
mysql> select course_id, credits
-> from course;
+-----------+---------+
| course_id | credits |
+-----------+---------+
| BIO-101 | 4 |
| BIO-301 | 4 |
| CS-101 | 4 |
| CS-190 | 4 |
| CS-315 | 3 |
| CS-319 | 3 |
| CS-347 | 3 |
| EE-181 | 3 |
| FIN-201 | 3 |
| HIS-351 | 3 |
| MU-199 | 3 |
| PHY-101 | 4 |
+-----------+---------+
這是我獲得學分數量的地方。
剛剛意識到3個NULL值來自實驗室中的上一個問題。 這些條目未在課程關系中表示。 我的問題解決了。 對於所有浪費的時間,我感到非常抱歉。
嘗試將其更改為:
UPDATE student as s
INNER JOIN takes as t ON s.ID = t.ID
INNER JOIN course as c ON t.course_id = c.course_id
SET s.tot_cred = s.tot_cred - COALESCE(c.credits, 0)
WHERE t.grade = 'F'
OR
t.grade IS NULL
檢查是否要替換為INNER JOIN而不是LEFT JOIN,因為您可能只想更新那些匹配記錄。
UPDATE student s
LEFT JOIN takes as t ON s.ID = t.ID and t.grade = 'F' OR t.grade is NULL
LEFT JOIN course as c ON t.course_id = c.course_id
SET tot_cred = tot_cred - COALESCE(c.credits, 0);
在這里檢查小提琴
我沒有意識到課程關系中沒有3個NULL值。 此查詢工作正常,對於所有浪費的時間,我們深表歉意。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.