簡體   English   中英

如何在 Snowflake 中將日期截斷為該月的第一天?

[英]How to truncate a date to the first day of the month in Snowflake?

我無法找到任何好的轉換代碼來將2014-02-17 into 2014-02-01而不必使用連接和大量格式。 我想知道是否有人可以幫我找到一個很好的命令來實現這一點。 謝謝!

Snowflake 支持數據類型DATETIMETIMESTAMPdate_trunc()

SELECT DATE_TRUNC(month, CURRENT_DATE()) AS first_day_of_month;

聽起來你正在使用字符串。 如果是這種情況並且它們將始終采用“yyyy-MM-dd”格式,您可以只取前 8 個字符並添加“01”:

left(MyStringValue, 8) + '01'

如果您正在使用日期字段,我喜歡做datediff從 0 開始獲取月份的技巧,然后使用帶 0 的dateadd返回到月份的第一天:

dateadd(month, datediff(month, 0, MyDateValue), 0)

這是另一種選擇:

SELECT TRUNCTIMESTAMPTOMONTH(CURRENT_DATE());

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM