SQLite Tutorial SQLite Advanced SQLite Database SQLite References

SQLite JULIANDAY() Function



The SQLite JULIANDAY() function takes a date and applies modifiers on it and then returns the date as a Julian Day.

A Julian Day is the number of days since November 24, 4714 BC 12:00 P.M Greenwich time in the Gregorian calendar. This function returns the date as a floating point number.

Syntax

JULIANDAY(time-value, modifier, modifier, ...)

Parameters

time-value

Required. Specify a time-value. It can be one of the following:

time-valueDescription
YYYY-MM-DDDate value formatted as 'YYYY-MM-DD'
YYYY-MM-DD HH:MMDate value formatted as 'YYYY-MM-DD HH:MM'
YYYY-MM-DD HH:MM:SSDate value formatted as 'YYYY-MM-DD HH:MM:SS'
YYYY-MM-DD HH:MM:SS.SSSDate value formatted as 'YYYY-MM-DD HH:MM:SS.SSS'
YYYY-MM-DDTHH:MMDate value formatted as 'YYYY-MM-DDTHH:MM' where T is a literal character separating the date and the time
YYYY-MM-DDTHH:MM:SSDate value formatted as 'YYYY-MM-DDTHH:MM:SS' where T is a literal character separating the date and the time
YYYY-MM-DDTHH:MM:SS.SSSDate value formatted as 'YYYY-MM-DDTHH:MM:SS.SSS' where T is a literal character separating the date and the time
HH:MMDate value formatted as 'HH:MM'
HH:MM:SSDate value formatted as 'HH:MM:SS'
HH:MM:SS.SSSDate value formatted as 'HH:MM:SS.SSS'
nownow is a literal used to return the current date.
DDDDDDDDDDJulian date number
modifier, modifier, ...

Optional. Specify modifiers. Each modifier is a transformation that is applied to the time value to its left. Modifiers are applied from left to right and are cumulative. The available modifiers are as follows:

modifierDescription
[+-]NNN daysNumber of days added/subtracted to the date
[+-]NNN hoursNumber of hours added/subtracted to the date
[+-]NNN minutesNumber of minutes added/subtracted to the date
[+-]NNN.NNNN secondsNumber of seconds (and fractional seconds) added/subtracted to the date
[+-]NNN monthsNumber of months added/subtracted to the date
[+-]NNN yearsNumber of years added/subtracted to the date
start of monthShifting the date back to the start of the month
start of yearShifting the date back to the start of the year
start of dayShifting the date back to the start of the day
weekday NMoves the date forward to the next date where weekday number is N
(0=Sunday, 1=Monday, 2=Tuesday, 3=Wednesday, 4=Thursday, 5=Friday, 6=Saturday)
unixepochUsed with the DDDDDDDDDD format to interpret the date as UNIX Time (ie: number of seconds since 1970-01-01)
juliandayUsed with the DDDDDDDDDD format to force the time-value number to be interpreted as a julian-day number
autoUsed with the DDDDDDDDDD format to interpret the time-value as either a julian day number or a unix timestamp, depending on its magnitude.
localtimeAdjusts date to localtime, assuming the time-value was expressed in UTC
utcAdjusts date to utc, assuming the time-value was expressed in localtime

Return Value

Returns the date as a Julian Day.

Example: Simple Date

The SQLite JULIANDAY() function can be used to convert a simple date to a Julian Day.

SELECT JULIANDAY('2018-08-18');
Result: '2458348.5'

SELECT JULIANDAY('2018-08-18 08:23:19');
Result: '2458348.84952546'

Example: Current Date and time

The SQLite 'now' time-value can be used to get the current date and time.

SELECT JULIANDAY('now');
Result: '2459679.01231368'

Example: First day of the month

To get the first day of the month, 'start of month' modifier can be used. See the example below:

SELECT JULIANDAY('2018-08-18 08:23:19', 'start of month');
Result: '2458331.5'

SELECT JULIANDAY('now', 'start of month');
Result: '2459670.5'

Example: Last day of the month

To get the last day of the month, first, the 'start of month' modifier is used to calculate the start day of the month and then 1 month is added and then 1 day is subtracted.

SELECT JULIANDAY('2018-08-18', 'start of month', '+1 month', '-1 day');
Result: '2458361.5'

SELECT JULIANDAY('now', 'start of month', '+1 month', '-1 day');
Result: '2459699.5'

Example: Adding/Subtracting years

To add/subtract years from a time-value, [+-]NNN years modifier can be used. In the example below 2 years is added and subtracted from a given time-value.

SELECT JULIANDAY('2018-08-18 08:23:19', '+2 years');
Result: '2459079.84952546'

SELECT JULIANDAY('2018-08-18 08:23:19', '-2 years');
Result: '2457618.84952546'

Example: Adding/Subtracting days

To add/subtract days drom a time-value, [+-]NNN days modifier can be used. In the example below 10 days is added and subtracted from a given time-value.

SELECT JULIANDAY('2018-08-18 08:23:19', '+10 days');
Result: '2458358.84952546'

SELECT JULIANDAY('2018-08-18 08:23:19', '-10 days');
Result: '2458338.84952546'

Example: Adding/Subtracting hours

To add/subtract hours from a time-value, [+-]NNN hours modifier can be used. In the example below 5 hours is added and subtracted from a given time-value.

SELECT JULIANDAY('2018-08-18 08:23:19', '+5 hours');
Result: '2458349.0578588'

SELECT JULIANDAY('2018-08-18 08:23:19', '-5 hours');
Result: '2458348.64119213'

Example: Adding/Subtracting minutes

To add/subtract minutes from a time-value, [+-]NNN minutes modifier can be used. In the example below 30 minutes is added and subtracted from a given time-value.

SELECT JULIANDAY('2018-08-18 08:23:19', '+30 minutes');
Result: '2458348.8703588'

SELECT JULIANDAY('2018-08-18 08:23:19', '-30 minutes');
Result: '2458348.82869213'

❮ SQLite Functions