Soft_Job 板


LINE

嗨,各位三百萬大大 想針對原文的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
6F:推 alihue: https://goo.gl/dL5c2V 08/25 21:56
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







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Soft_Job站內搜尋

TOP