從SQL Server的日期時間值中擷取日期
大多數SQL應用程式處理包含日期和時間成分的資料。然而,在某些情況下,我們只需要提取日期部分,而丟棄時間資訊。這可以透過SQL Server中的各種技術有效地實現。
最高效的方法
雖然有幾種方法,但在SQL Server中從datetime提取日期的最有效方法是結合使用DATEADD()函數和DATEDIFF()函數。此方法包括以下步驟:
例如:
<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中文網其他相關文章!