Working with Dates and Times
Working with dates and times is a notoriously difficult problem, the most famous incantation being Y2K. Airkit provides a comprehensive system to work with dates and times for this precise reason. There are three data types to familiarize yourself with, the Datetime, the Date, and the Time types. The best way to think of these is by analogy. A Datetime is a specific time marked on your calendar. A Date is a particular day's square on your calendar. A Time is a particular configuration of your clock.
If you would like to find the current Datetime you can use the NOW function.
NOW()
Other ways to create a date/time are to use the functions DATETIME, DATE, and TIME. Using January 9th, 2007 9:41 AM as an example Datetime:
DATETIME(DATE(2007, 1, 9), TIME(9, 41, 0), "America/Los_Angeles")
DATE(2007, 1, 9)
TIME(9, 41, 0)
To retrieve the year of our example Date use the YEAR function:
YEAR(example_date)
The YEAR function can also be used to retrieve the year from our example Datetime:
YEAR(example_datetime)
Use the DATE_FROM_DATETIME and the TIME_FROM_DATETIME functions to convert a Datetime to a Date or Time respectively:
DATE_FROM_DATETIME(example_datetime)
TIME_FROM_DATETIME(example_datetime)
The following functions can be used to retrieve different parts of Datetimes, Dates, and Times
Function Name | Description |
---|---|
DATE_FROM_DATETIME | Returns the date portion of a Datetime. |
TIME_FROM_DATETIME | Returns the time portion of a Datetime. |
YEAR | Returns the year of a Datetime or Date |
MONTH | Returns the month of a Datetime or Date |
DAY | Returns the day of a Datetime or Date |
HOUR | Returns the hour of a Datetime or Time |
MINUTE | Returns the minute of a Datetime or Time |
SECOND | Returns the second of a Datetime or Time |
Formatting
The FORMAT_DATETIME, FORMAT_DATE, and FORMAT_TIME functions allow you to create a String from a Datetime, Date, or Time. Use these functions when you would like to display a Datetime, Date, or Time to a user so that Airkit can format it correctly according to the user's locale and timezone. For example, to display our example Datetime as January 9, 2007 9:41 AM PST:
FORMAT_DATETIME(example_datetime, "MMMM do, YYYY h:mm A")
or just the time as 9:41 AM:
FORMAT_DATETIME(example_datetime, "h:mm A")
Modifying
Modifying with a Specific Value
If you want to change a particular portion of a Datetime, there are several functions that will allow you to do so. For example, if you wanted to change the year of our example Datetime from 2007 to 2010, you would use the UPDATE_YEAR function to create a new Datetime by changing only the year:
UPDATE_YEAR(example_datetime, 2010)
This function works equally well on Dates:
UPDATE_YEAR(example_datetime, 2010)
If you wanted to update the calendar date of the Datetime, you can use the UPDATE_DATE function to create a new Datetime, with a new calendar date, but the same time:
UPDATE_DATE(example_datetime, DATE(2010, 4, 3))
Datetimes, Dates, and Times can be modified using the following functions
Function Name | Description |
---|---|
UPDATE_DATE | Changes the date portion of a Datetime. |
UPDATE_TIME | Changes the time portion of a Datetime. |
UPDATE_TIMEZONE | Changes the timezone of a Datetime. |
UPDATE_YEAR | Changes the year of a Datetime or Date |
UPDATE_MONTH | Changes the month of a Datetime or Date |
UPDATE_DAY | Changes the day of a Datetime or Date |
UPDATE_HOUR | Changes the hour of a Datetime or Time |
UPDATE_MINUTE | Changes the minute of a Datetime or Time |
UPDATE_SECOND | Changes the second of a Datetime or Time |
UPDATE_MILLISECOND | Changes the millisecond of a Datetime or Time |
Modifying with a Relative Value
The ADD_TO_DATETIME and SUBTRACT_FROM_DATETIME functions allow you to create a new date by adding or removing time units. You could add six months, or 169 days to our example date:
ADD_TO_DATETIME(example_datetime, 6, "M")
ADD_TO_DATETIME(example_datetime, 169, "d")
Timestamps
When interfacing with external systems, you'll often encounter Datetimes that are represented either as a Number or a String.
Datetime as a Number
An Epoch timestamp is a Number representing the number of seconds (or milliseconds) that have elapsed since January 1st, 1970. For example the timestamp in milliseconds for January 9ith, 2007 is 1168364460000. When you encounter a Datetime in this format look to the DATETIME_FROM_TIMESTAMP function which turns an Epoch timestamp measured in milliseconds into a proper Datetime.
DATETIME_FROM_TIMESTAMP(1168364460000)
To go in the other direction look no further than the TIMESTAMP_FROM_DATETIME function.
TIMESTAMP_FROM_DATETIME(example_datetime)
If your particular timestamp looks like it is missing three zeros than the previous example, you are likely working with timestamps in seconds, provide second parameter "s"
DATETIME_FROM_TIMESTAMP(1168364460, "s")
TIMESTAMP_FROM_DATETIME(example_datetime, "s")
Datetime as a String
The other commonly used timestamp type is a string with the format "YYYY-MM-DDTHH:mm:ssZ". To convert between a timestamp of this format and a Datetime use the DATETIME_FROM_FORMAT and FORMAT_DATETIME functions.
DATETIME_FROM_FORMAT("2007-01-09T09:41:00Z")
FORMAT_DATETIME(example_datetime)
Timezones
Note that one of our previous examples reproduced below included a timezone:
DATETIME(DATE(2007, 1, 9), TIME(9, 41, 0), "America/Los_Angeles")
This is important because, in addition to a Date and a Time, Datetimes also have an associated timezone.
Relevant Functions
- NOW
- TODAY
- DATETIME
- DATE
- TIME
- DATE_FROM_DATETIME
- TIME_FROM_DATETIME
- YEAR
- MONTH
- DAY
- HOUR
- MINUTE
- SECOND
- FORMAT_DATE
- FORMAT_TIME
- UPDATE_DATE
- UPDATE_TIME
- UPDATE_TIMEZONE
- UPDATE_YEAR
- UPDATE_MONTH
- UPDATE_DAY
- UPDATE_HOUR
- UPDATE_MINUTE
- <UPDATE_SECOND>
- UPDATE_MILLISECOND
- ADD_TO_DATETIME
- SUBTRACT_FROM_DATETIME
- DATE_DELTA
- TIME_DELTA
- DATETIME_FROM_TIMESTAMP
- TIMESTAMP_FROM_DATETIME
- DATETIME_FROM_FORMAT
- DATE_FROM_FORMAT
- TIME_FROM_FORMAT
Updated about 2 years ago