作者angle065 (Fu)
看板Soft_Job
標題Re: [請益] 請問 MySQL 推薦書籍
時間Sat Aug 25 20:57:57 2018
嗨,各位三百萬大大
想針對原文的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://webptt.com/m.aspx?n=bbs/Soft_Job/M.1535201879.A.119.html
1F:推 drajan: 設一個常數k作為行數 從原始資料表select k 學號 分數 再g 08/25 21:24
2F:→ drajan: roup by 學號 max(k)即得 08/25 21:24
謝謝你的分享,我Google也有看到這個解法
但想說有沒有更簡單一點的 XD
※ 編輯: angle065 (115.43.61.37), 08/25/2018 21:25:30
3F:→ drajan: 忘記說 k:=k+1 08/25 21:25
4F:→ NodeWay: 這個case 好像用nosql來做會更適合 08/25 21:38
5F:→ NodeWay: 你已經知道使用情境了 一張表存歷史成績 一張表存最新 08/25 21:38
7F:→ alan3100: windowfuntction 10年前就出現了,別浪費生命在刻東西 08/25 22:39
8F:→ alan3100: Oracle/MSSQL 2008之前就支援最基本的rownumber 08/25 22:43
9F:→ alan3100: mysql&mariadb好像在2017前後也支援, AWS-RDS今年也支援 08/25 22:44
10F:→ alan3100: 前述有windowfunction & CTE 的版本 08/25 22:45
謝謝你的分享,我再裝新版的Mysql試試看,目前公司測試機5.1板不支援的樣子 QQ
※ 編輯: angle065 (115.43.61.37), 08/25/2018 23:18:14