Re: [請益] 請問 MySQL 推薦書籍
嗨,各位三百萬大大
想針對原文的SQL問題討論解法是否正確
一張資料表儲存 某高中 三年級 今年所有考試的分數,一共十五萬筆資料
資料表欄位包:含學號、考試時間、考試分數。
然後,每三分鐘問一次,每一個學生最後一次考試的分數是多少?
因為以前工作只使用過Oracle & MSSQL,最近換到MySQL,對這個問題也很困擾
之前再MSSQL或Oracle的解法是使用row_number() over(partition by)來處理
MySQL好像沒有row_number()這個解法,剛剛自己嘗試後的解法會變成
Select
學號,max(時間)
From table
Group by 學號
這樣可以找到每個學號最後一次考試的時間
假設考試時間不重複,再join一次自己,就可以算出最後一次的分數
但若允許時間重複,這樣還是無法找到答案
想請問若再Mysql要解這種題目,有什麼更好的方法嗎?
※ 引述《p52189 (鼠霸)》之銘言:
: 大家好
: 因為工作需求,需要增進一些 MySQL 的能力
: 打工不算的話本人經驗約一年半,使用LAMP
: 資料庫只會很初級的 CRUD ,稍微複雜一點的 query 都不會
: 這裡提供一個我不會寫的範本:
: 一張資料表儲存 某高中 三年級 今年所有考試的分數,一共十五萬筆資料,資料表欄位包含:學號、考試時間、考試分數。然後,每三分鐘問一次,每一個學生最後一次考試的分數是多少?
: 類似這種問題通常我可以下一些關鍵字在 Stack Overflow上面找到類似的發問,然後修改一下得到解答
: 或者如果考試程式是我寫的,乾脆每次考試把最後一筆快取起來
: 但是這樣顯然不是根本的解決之道
: 所以我需要一本比 Head First 稍微進階一點的書,讓我能解一些稍微困難一點點的問題
: 書最好是中文
: 然後也不要太難…什麼「精妙的資料庫語句 」、「MySQL 之美」之類的(這兩本書名我瞎掰的)……那種書太難我看不懂囧
: 然後也不要整本全部都範例幾乎沒篇幅在講思路的,例如「MySQL 即戰一百招」(這也是我瞎掰的)這種書
: 理想的結構是先講述一個情境,例如我文中舉的高中生考試的例子,然後先示範菜鳥如何寫爛 code,爛 code 發生什麼問題,如何避開這些問題,從簡單的 case 到困難的
: 大概就這樣……不知道會不會太囉嗦……總之請板友推薦,謝謝
: -----
: Sent from JPTT on my HTC_M9u.
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 115.43.61.37
※ 文章網址: https://www.ptt.cc/bbs/Soft_Job/M.1535201879.A.119.html
推
08/25 21:24,
5年前
, 1F
08/25 21:24, 1F
→
08/25 21:24,
5年前
, 2F
08/25 21:24, 2F
謝謝你的分享,我Google也有看到這個解法
但想說有沒有更簡單一點的 XD
※ 編輯: angle065 (115.43.61.37), 08/25/2018 21:25:30
→
08/25 21:25,
5年前
, 3F
08/25 21:25, 3F
→
08/25 21:38,
5年前
, 4F
08/25 21:38, 4F
→
08/25 21:38,
5年前
, 5F
08/25 21:38, 5F
推
08/25 21:56,
5年前
, 6F
08/25 21:56, 6F
→
08/25 22:39,
5年前
, 7F
08/25 22:39, 7F
→
08/25 22:43,
5年前
, 8F
08/25 22:43, 8F
→
08/25 22:44,
5年前
, 9F
08/25 22:44, 9F
→
08/25 22:45,
5年前
, 10F
08/25 22:45, 10F
謝謝你的分享,我再裝新版的Mysql試試看,目前公司測試機5.1板不支援的樣子 QQ
※ 編輯: angle065 (115.43.61.37), 08/25/2018 23:18:14
討論串 (同標題文章)