你有一個開始時間戳並在數據庫中結束時間戳。您希望根據這些值之間的時間跨度爲這些值添加額外的時間百分比。換句話說,如果不知道兩者之間的差異,則無法增加或減少任何時間。
所以,首先你必須找出時間跨度。我將使用分鐘爲單位,而是隨便用最適合您的需要:
SELECT
@new_span := TIMESTAMPDIFF(MINUTE, timestamp1, timestamp2) * 1.25 new_span,
DATE_SUB(timestamp1, INTERVAL (@new_span*60)/2 SECOND) AS new_start,
DATE_ADD(timestamp2, INTERVAL (@new_span*60)/2 SECOND) AS new_end,
TIMESTAMPDIFF(MINUTE, timestamp1, timestamp2) old_span,
timestamp1 AS previous_start,
timestamp2 AS previous_end
FROM table;
所以這個查詢存儲兩次加25%作爲命名new_span
變量之間的區別。 new_start
和new_end
字段使用變量(轉換爲秒並分成兩半)來修改原始開始/結束時間。我還選擇了old_span和原始開始/結束時間,以供比較。
下面是示例輸出:
new_span new_start new_end old_span previous_start previous_end
1.25 2011-08-11 15:53:22 2011-08-11 15:55:38 1 2011-08-11 15:54:00 2011-08-11 15:55:00
1350.00 2011-08-09 00:45:00 2011-08-10 17:15:00 1080 2011-08-09 12:00:00 2011-08-10 06:00:00
美麗!我在那裏工作,但這真的幫了我很多時間。謝謝! – Kevin