Re: [請益] 請問 MySQL 推薦書籍

看板Soft_Job作者 (Fu)時間5年前 (2018/08/25 20:57), 5年前編輯推噓2(208)
留言10則, 4人參與, 5年前最新討論串2/2 (看更多)
嗨,各位三百萬大大 想針對原文的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
設一個常數k作為行數 從原始資料表select k 學號 分數 再g
08/25 21:24, 1F

08/25 21:24, 5年前 , 2F
roup by 學號 max(k)即得
08/25 21:24, 2F
謝謝你的分享,我Google也有看到這個解法 但想說有沒有更簡單一點的 XD ※ 編輯: angle065 (115.43.61.37), 08/25/2018 21:25:30

08/25 21:25, 5年前 , 3F
忘記說 k:=k+1
08/25 21:25, 3F

08/25 21:38, 5年前 , 4F
這個case 好像用nosql來做會更適合
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
windowfuntction 10年前就出現了,別浪費生命在刻東西
08/25 22:39, 7F

08/25 22:43, 5年前 , 8F
Oracle/MSSQL 2008之前就支援最基本的rownumber
08/25 22:43, 8F

08/25 22:44, 5年前 , 9F
mysql&mariadb好像在2017前後也支援, AWS-RDS今年也支援
08/25 22:44, 9F

08/25 22:45, 5年前 , 10F
前述有windowfunction & CTE 的版本
08/25 22:45, 10F
謝謝你的分享,我再裝新版的Mysql試試看,目前公司測試機5.1板不支援的樣子 QQ ※ 編輯: angle065 (115.43.61.37), 08/25/2018 23:18:14
文章代碼(AID): #1RWL9N4P (Soft_Job)
文章代碼(AID): #1RWL9N4P (Soft_Job)