你們都知道update更新語句:update 表名 set 字段=值。彷佛很簡單mybatis
可是今天我遇到這樣一個問題:我須要更新一張叫PO_SPECIAL_TASK_LINE表的score字段,這個分數經過另一張打分詳情表(special_assessment_score_detail)計算出來的,spa
他們之間的關聯是字段是taskId和taskLineID。ci
好了,我立刻就寫出了以下語句:源碼
update PO_SPECIAL_TASK_LINEdate
set score=(im
SELECT SUM(score) FROM
(SELECT AVG(CONVERT(decimal,score)) score,TASK_LINE_ID FROM dbo.special_assessment_score_detail WHERE TASK_ID=''
GROUP BY TASK_LINE_ID,SPECIAL_INDICATORS_ID) a
GROUP BY TASK_LINE_ID數據
)項目
where task_id=''查詢
目的很簡單,經過一張打分表算出當前任務的全部行的每一個指標的平均分並求和更新到任務行表的對應行中db
上面的寫法若是是一個任務只有一行是沒有問題的,可是若是一個任務有多行數據,我須要批量更新的話,顯然這是不行的。
那麼這裏就用到了update的高級用法(自我稱之爲高級):
update 表1
set 表1.score=表2.score
from 表1,
表2
where 表1.task_line_id=表2.task_line_id
這裏的表2能夠是一個查詢視圖,老鐵們是否是以爲很高級,這樣無論表2中有幾個score,均可以對應更新到表1中了
這裏也貼上我在項目中的源碼:
UPDATE dbo.PO_SPECIAL_TASK_LINE
SET PO_SPECIAL_TASK_LINE.SCORE=a.score
FROM PO_SPECIAL_TASK_LINE,
(SELECT CAST(ROUND(SUM(score),0) AS INT) score,TASK_LINE_ID
FROM (
SELECT AVG(CONVERT(decimal,score)) score,TASK_LINE_ID FROM dbo.special_assessment_score_detail WHERE TASK_ID=#{taskId} AND PROCESS_STATUS IN ('4','5','0') GROUP BY SPECIAL_INDICATORS_ID,TASK_LINE_ID
)s GROUP BY TASK_LINE_ID) a
WHERE PO_SPECIAL_TASK_LINE.TASK_LINE_ID=a.TASK_LINE_ID
AND PO_SPECIAL_TASK_LINE.TASK_ID=#{taskId}
這是mybatis中XML中的代碼,參數就是任務ID(taskId)