MySQL:控制組傳回的行的選擇
在MySQL 中,擷取每個ID 具有最高版本的行可以是一項複雜的任務。但是,可以採用多種方法來實現此目標。
一種方法是利用子查詢:
SELECT * FROM (SELECT * FROM table ORDER BY version_id DESC) t1 GROUP BY t1.id
此子查詢按版本 ID 降序對行進行排序每個 ID。隨後,主查詢會依 ID 將排序後的行分組。這種方法會在記憶體中建立一個臨時表,但如果 (id, version_id) 列上存在索引,則效率會更高。
另一個策略涉及巢狀查詢:
SELECT * FROM (SELECT id, max(version_id) as version_id FROM table GROUP BY id) t1 INNER JOIN table t2 on t2.id=t1.id and t1.version_id=t2.version_id
此查詢計算子查詢中每個 ID 的最大版本 ID。然後主查詢使用 ID 和 version_id 列將子查詢與原始表連接起來,以檢索具有最大版本 ID 的行。
這兩種方法都提供了為每個 ID 選擇具有最高版本 ID 的行的有效解決方案。最合適的方法取決於應用程式的特定要求和效能考慮。
以上是MySQL中如何為每個ID選擇版本ID最高的行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!