Date and Time TRUNC
Truncates a DATE
or DATETIME
value to a specified resolution.
For example, truncating a DATE
down to the nearest month returns the date of the first day of the month.
Note
This function is overloaded. The function TRUNC can also round numbers towards zero.
Syntax
TRUNC( date_expr [ , interval ])
interval ::=
YEAR | YYYY | YY
| QUARTER | QQ | Q
| MONTH | MM | M
| DAY | DD | D
| WEEK | WK | WW
| HOUR | HH
| MINUTE | MI | N
| SECOND | SS | S
| MILLISECOND | MS
Arguments
Parameter |
Description |
---|---|
|
A |
|
An interval representing a date part. See the table below or the syntax reference above for valid date parts. If not specified, sets the value to to midnight and returns a |
Valid date parts
Date part |
Shorthand |
Definition |
---|---|---|
|
|
Year (0 - 9999) |
|
|
Quarter (1-4) |
|
|
Month (1-12) |
|
|
Day of the month (1-31) |
|
|
Week of the year (1-52) |
|
|
Hour (0-23) |
|
|
Minute (0-59) |
|
|
Seconds (0-59) |
|
|
Milliseconds (0-999) |
Returns
If no date part is specified, the return type is DATETIME
. Otherwise, the return type is the same as the argument supplied.
Notes
All date parts work on a
DATETIME
.The
HOUR
,MINUTE
,SECOND
, andMILLISECOND
date parts work only onDATETIME
. Using them onDATE
will result in an error.If no date part is specified, the
DATE
orDATETIME
value will be set to midnight on the date value. See examples belowSee also EOMONTH to find the last day of the month.
Examples
For these examples, consider the following table and contents:
CREATE TABLE cool_dates(name VARCHAR(40), d DATE, dt DATETIME);
INSERT INTO cool_dates VALUES ('Marty McFly goes back to this time','1955-11-05','1955-11-05 01:21:00.000')
, ('Marty McFly came from this time', '1985-10-26', '1985-10-26 01:22:00.000')
, ('Vesuvius erupts', '79-08-24', '79-08-24 13:00:00.000')
, ('1997 begins', '1997-01-01', '1997-01-01')
, ('1997 ends', '1997-12-31','1997-12-31 23:59:59.999');
Set all DATE
columns to DATETIME
at midnight
master=> SELECT name, d AS date, trunc(d) FROM cool_dates;
name | date | trunc
-----------------------------------+------------+--------------------
Marty McFly goes back to this time | 1955-11-05 | 1955-11-05 00:00:00
Marty McFly came from this time | 1985-10-26 | 1985-10-26 00:00:00
Vesuvius erupts | 0079-08-24 | 0079-08-24 00:00:00
1997 begins | 1997-01-01 | 1997-01-01 00:00:00
1997 ends | 1997-12-31 | 1997-12-31 00:00:00
Find the first day of the month for dates
master=> SELECT name, d AS date, trunc(d, MONTH) FROM cool_dates;
name | date | trunc
-----------------------------------+------------+-----------
Marty McFly goes back to this time | 1955-11-05 | 1955-11-01
Marty McFly came from this time | 1985-10-26 | 1985-10-01
Vesuvius erupts | 0079-08-24 | 0079-08-01
1997 begins | 1997-01-01 | 1997-01-01
1997 ends | 1997-12-31 | 1997-12-01
Calculate number of hours from New Years
Combine TRUNC
with DATEDIFF to calculate the number of hours since New Years.
master=> SELECT name, dt AS datetime,
. , DATEDIFF(HOUR, trunc(dt, YEAR), dt) AS "Hours since New Years"
. FROM cool_dates;
name | datetime | Hours since New Years
-----------------------------------+---------------------+----------------------
Marty McFly goes back to this time | 1955-11-05 01:21:00 | 7393
Marty McFly came from this time | 1985-10-26 01:22:00 | 7153
Vesuvius erupts | 0079-08-24 13:00:00 | 5653
1997 begins | 1997-01-01 00:00:00 | 0
1997 ends | 1997-12-31 23:59:59 | 8759