[討論] Join效能請益
小弟入行約一年,算有點前後端經驗。
目前在工作上遇到問題,想請各前輩解惑。
我目前寫前端,遇到需要的資料沒有API時,
會開需求給我們後端工程師。
假設我今日要查詢的是:
該名學生的班級、導師、導師教授科目,三種
在已知學生的id情況,查尋上述三種資料。
都為一對一,且必須依序查班級、導師、導師教授科目查詢。
問題來了,
我的直覺是用學生id查詢所屬班級,並join導師及導師教授科目,用一個Request查詢所
需資料。
後端工程師卻覺得join很消耗DB效能,必須把效能留在新增刪除修改這類的地方,要我多
發兩次請求查詢(導師、導師教授科目),對DB較無負擔。
再者,請他分三次SQL查詢,他說Java後端是同步語法,在等待SQL查詢回來時Thread會卡
在那不做事,查三個很浪費時間。
然後我自己寫SQL測試查詢速度,發現不管有沒有join資料表,查詢速度皆差不到2ms
他的回應是join會使用更多的系統資源,所以查詢速度會差不多
這裡想請問,join真的很消耗效能嗎?
備註:前端-vue,後端-Spring Boot,DB-PostgreSQL
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 124.218.32.84 (臺灣)
※ 文章網址: https://www.ptt.cc/bbs/Database/M.1590590601.A.21E.html
推
05/27 23:39,
4年前
, 1F
05/27 23:39, 1F
→
05/27 23:54,
4年前
, 2F
05/27 23:54, 2F
我心裡的第一個os的確是這麼想,但覺得這會無限上綱
→
05/27 23:58,
4年前
, 3F
05/27 23:58, 3F
→
05/27 23:59,
4年前
, 4F
05/27 23:59, 4F
→
05/28 00:18,
4年前
, 5F
05/28 00:18, 5F
→
05/28 00:49,
4年前
, 6F
05/28 00:49, 6F
所以重要還是看DB設定還有SQL寫法?
→
05/28 06:47,
4年前
, 7F
05/28 06:47, 7F
他倒是有讓我看Explain,但DB不做也是落到前端做,雖然是在使用者電腦,資料多的話
也怕前端處理慢
推
05/28 07:00,
4年前
, 8F
05/28 07:00, 8F
※ 編輯: James610024 (115.82.227.109 臺灣), 05/28/2020 09:16:31
→
05/28 12:16,
4年前
, 9F
05/28 12:16, 9F
→
05/28 12:19,
4年前
, 10F
05/28 12:19, 10F
→
05/28 12:19,
4年前
, 11F
05/28 12:19, 11F
是沒錯
→
05/28 12:20,
4年前
, 12F
05/28 12:20, 12F
→
05/28 12:21,
4年前
, 13F
05/28 12:21, 13F
了解,我再試試,先感謝大大
既然提到多個請求,這邊想再請問說:
如果原本一個請求可以解決變成三個請求,變相的後端server與DB都要額外執行兩次處理
與查詢,十位user就會乘10倍,等於server與DB多處理20個,這樣應該怎麼衡量Request
數量與是否join table呢?
※ 編輯: James610024 (115.82.227.109 臺灣), 05/28/2020 12:57:41
→
05/28 14:20,
4年前
, 14F
05/28 14:20, 14F
→
05/28 14:20,
4年前
, 15F
05/28 14:20, 15F
好的,了解
※ 編輯: James610024 (115.82.227.109 臺灣), 05/28/2020 16:47:20
推
06/03 04:06,
4年前
, 16F
06/03 04:06, 16F
推
06/03 04:08,
4年前
, 17F
06/03 04:08, 17F
推
06/04 00:09,
4年前
, 18F
06/04 00:09, 18F
Database 近期熱門文章
PTT數位生活區 即時熱門文章