從MySQL 檢索時間戳差異(以秒為單位)
確定兩個時間戳之間的時間差是一項常見的資料庫任務。 MySQL 提供了本機函數來簡化此計算,因此無需在 PHP 中進行手動轉換。本文探討了使用 MySQL 取得時間戳記之間基於秒的差異的兩種方法。
方法 1:TIMEDIFF() 和 TIME_TO_SEC()
TIMEDIFF() 函數計算兩個時間戳記之間的差異並以 TIME 資料類型傳回結果。此資料類型保存時間間隔,範圍從「-838:59:59」到「838:59:59」。若要將 TIME 值轉換為秒,請使用 TIME_TO_SEC() 函數。
範例:
SELECT TIME_TO_SEC(TIMEDIFF('2010-08-20 12:01:00', '2010-08-20 12:00:00')) diff;
結果將為 60 秒,代表時差在給定的時間戳之間。
方法 2: UNIX_TIMESTAMP()
UNIX_TIMESTAMP() 函數取自 Unix 紀元(UTC 1970 年 1 月 1 日)開始以來經過的秒數。使用此函數,只需將較早的時間戳記減去較晚的時間戳記即可計算出兩個時間戳記之間的差異。
範例:
SELECT UNIX_TIMESTAMP('2010-08-20 12:01:00') - UNIX_TIMESTAMP('2010-08-20 12:00:00') diff;
此方法略使用 TIMESTAMP 資料型別時速度較快,因為 TIMESTAMP 值在內部儲存為表示 Unix 時間的整數。
以上是如何使用MySQL高效計算秒級時間戳記差異?的詳細內容。更多資訊請關注PHP中文網其他相關文章!