在MySQL 中使用Group By 選擇最新值
當嘗試使用MySQL 的GROUP BY 子句檢索每個使用者的最新出席情況時,您可能會遇到返回初始出勤率而不是所需的最新值的情況。
使用子查詢
一個解決方案是利用子查詢來識別最大時間戳對於每個成員,並將此子查詢與主表連接:
<code class="sql">SELECT * FROM view_event_attendance AS t1 WHERE id_event = 782 AND timestamp = (SELECT MAX(timestamp) FROM view_event_attendance AS t2 WHERE t1.id_member = t2.id_member AND t1.id_event = t2.id_event GROUP BY id_event, id_member) GROUP BY id_event, id_member;</code>
使用串聯和MAX()
另一種方法是將時間戳和出勤值連接起來,然後使用MAX() 選擇組合值:
<code class="sql">SELECT substring(max(concat(from_unixtime(timestamp),attendance)) from 20) as attendance FROM view_event_attendance WHERE id_event = 782 GROUP BY id_event,id_member;</code>
此方法僅傳回每個成員的最新出勤值。
選擇串聯時間戳/出勤
如果您想檢索連接的時間戳和出勤值,可以使用以下查詢:
<code class="sql">SELECT concat(from_unixtime(timestamp),attendance), timestamp, attendance FROM view_event_attendance WHERE id_event = 782 GROUP BY id_event,id_member;</code>
效能注意事項
交易時對於大型資料集,子查詢的計算成本可能很高。連接值並使用 MAX() 可以提供更好的效能。但是,評估特定要求和資料庫特徵以確定適合您的用例的最佳解決方案非常重要。
以上是如何使用 MySQL 的 GROUP BY 子句檢索每個使用者的最新考勤狀況?的詳細內容。更多資訊請關注PHP中文網其他相關文章!