如何使用 MySQL 的 GROUP BY 子句檢索每個使用者的最新考勤狀況?

DDD
發布: 2024-10-28 05:15:30
原創
135 人瀏覽過

How to Retrieve the Latest Attendance for Each User Using MySQL's GROUP BY Clause?

在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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!