首頁 >資料庫 >mysql教程 >如何從 SQL Server 中的日期時間值中高效率地提取日期部分?

如何從 SQL Server 中的日期時間值中高效率地提取日期部分?

Susan Sarandon
Susan Sarandon原創
2025-01-13 07:55:42981瀏覽

How Can I Efficiently Extract the Date Part from a DateTime Value in SQL Server?

從SQL Server的日期時間值中擷取日期

大多數SQL應用程式處理包含日期和時間成分的資料。然而,在某些情況下,我們只需要提取日期部分,而丟棄時間資訊。這可以透過SQL Server中的各種技術有效地實現。

最高效的方法

雖然有幾種方法,但在SQL Server中從datetime提取日期的最有效方法是結合使用DATEADD()函數和DATEDIFF()函數。此方法包括以下步驟:

  1. 使用DATEDIFF(DAY, 0, )計算0和給定datetime之間的天數。此步驟有效計算從紀元(1900年1月1日)起的每日偏移量。
  2. 將DATEADD()應用於DAY字段,並使用步驟1的結果來獲得一個新的datetime,其時間組件重置為00:00:00。

例如:

<code class="language-sql">SELECT DATEADD(DAY, DATEDIFF(DAY, 0, '2008-09-25 12:34:56'), 0)</code>

與其他選項(例如使用CAST(FLOOR(CAST(... AS FLOAT)) AS DATETIME)或CONVERT(DATETIME, CONVERT(VARCHAR(10), ..., 120), 120)轉換)相比,此方法已被證明是最快、最有效的方法。

基準測試

在包含超過1.3億行記錄的資料集(其時間戳精確到毫秒級)上進行的效能測試顯示了以下結果:

方法 CPU时间(ms)
纯SELECT 422
Floor-Cast 625
字符串转换 1953
DateAdd 531

值得注意的是,效能可能會因資料的大小、分佈和其他因素而異。

以上是如何從 SQL Server 中的日期時間值中高效率地提取日期部分?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn