TRUNC
引入版本: v1.2.745
将日期或时间戳截断到指定精度。此函数遵循广泛采用的日期截断语法,便于从其他数据库系统迁移的用户使用。
语法
TRUNC(<date_or_timestamp>, <datetime_interval_type>)
| 参数 | 描述 | 
|---|---|
| <date_or_timestamp> | DATE或TIMESTAMP类型的值。 | 
| <datetime_interval_type> | 必须是以下值之一: YEAR、QUARTER、MONTH、WEEK、DAY、HOUR、MINUTE、SECOND。 | 
周起始配置
当使用 WEEK 作为日期时间间隔类型时,结果取决于 week_start 设置,该设置定义了一周的第一天:
- week_start = 1(默认): 周一被视为一周的第一天
- week_start = 0: 周日被视为一周的第一天
您可以使用 SETTINGS 子句为特定查询更改此设置:
-- 设置周日为一周的第一天
SETTINGS (week_start = 0) SELECT TRUNC(to_date('2024-04-05'), 'WEEK');
-- 设置周一为一周的第一天 (默认)
SETTINGS (week_start = 1) SELECT TRUNC(to_date('2024-04-05'), 'WEEK');
返回类型
与 <date_or_timestamp> 相同。
示例
-- 截断到不同精度
SELECT
    TRUNC(to_date('2022-07-07'), 'MONTH'),
    TRUNC(to_date('2022-07-07'), 'WEEK'),
    TRUNC(to_date('2022-07-07'), 'YEAR');
┌────────────────────────────────────────────────────────────────────────────────────┐
│ TRUNC(to_date('2022-07-07'), 'MONTH') │ TRUNC(to_date('2022-07-07'), 'WEEK') │ TRUNC(to_date('2022-07-07'), 'YEAR') │
├──────────────────────────────────────┼─────────────────────────────────────┼─────────────────────────────────────┤
│ 2022-07-01                           │ 2022-07-04                          │ 2022-01-01                          │
└────────────────────────────────────────────────────────────────────────────────────┘
以下示例演示了 week_start 设置如何影响使用 WEEK 精度的 TRUNC 结果:
-- 默认: week_start = 1 (周一为一周第一天)
SELECT TRUNC(to_date('2024-04-03'), 'WEEK');  -- 周三
┌─────────────────────────────────────┐
│ TRUNC(to_date('2024-04-03'), 'WEEK') │
├─────────────────────────────────────┤
│ 2024-04-01                          │ -- 周一
└─────────────────────────────────────┘
-- 设置 week_start = 0 (周日为一周第一天)
SETTINGS (week_start = 0) SELECT TRUNC(to_date('2024-04-03'), 'WEEK');  -- 周三
┌─────────────────────────────────────┐
│ TRUNC(to_date('2024-04-03'), 'WEEK') │
├─────────────────────────────────────┤
│ 2024-03-31                          │ -- 周日
└─────────────────────────────────────┘
对时间戳值使用 TRUNC:
SELECT TRUNC(to_timestamp('2022-07-07 15:30:45.123456'), 'DAY');
┌───────────────────────────────────────────────────────┐
│ TRUNC(to_timestamp('2022-07-07 15:30:45.123456'), 'DAY') │
├───────────────────────────────────────────────────────┤
│ 2022-07-07 00:00:00.000000                            │
└───────────────────────────────────────────────────────┘

