Skip to main content
Version: 2.0.0

Temporal types

Temporal types can be stored as properties of a vertex or edge. The user can use Cypher queries or procedures to read or write these properties. The following table summarizes the temporal types that Memgraph currently supports:

namedescription
DurationData type that represents a period of time.
DateData type that represents a date with year, month and day.
LocalTimeData type that represents time within a day without timezone.
LocalDateTimeData type that represents a date and local time.

Note, that all the types excluding Durations are ISO 8601 compliant.

Duration​

You can create Duration from a string or a map by calling the function duration.

For strings, the duration format is:

P[nD]T[nH][nM][nS] where n stands for number and the capital letters are used as a separator with each field in [] marked optional. For strings Memgraph only allows the last field to be a double, e.g, P2DT2.5H. However, for maps, every field can be a double, an int or a mixture of both. Note, we support negative durations.

namedescription
DDays
HHours
MMinutes
SSeconds

Example:

CREATE (:F1Laps {lap : duration("PT2M2.33S")})

Maps can contain the following six fields: day, hour, minute, second, millisecond and microsecond.

Example:

CREATE (:F1Laps {lap : duration({minute:2, seconds:2, microseconds:33})})

At this point, it must be pointed out that durations internally hold microseconds. Each of the fields specified above is first converted to microseconds and then reduced by addition to a single value. This has an interesting use case:

CREATE (:F1Laps {lap : duration({minute:2, seconds:-2, microseconds:-33})})

This converts minutes, seconds to microseconds and effectively produces the following equation: minutes - seconds - microseconds.

Each of the individual fields of a duration can be accessed through its properties as follows:

namedescription
dayThis converts all the microseconds to days and returns them.
hourThis subtracts days and returns the leftover as hours.
minuteThis subtracts the days and returns the leftover as minutes.
secondThis subtracts the days and returns the leftover as seconds.
millisecondThis subtracts the days and returns the leftover as milliseconds.
microsecondThis subtracts the days and returns the leftover as microseconds.
nanosecondThis subtracts the days and returns the leftover as nanoseconds.

Example:

MATCH (f:F1Laps) RETURN f.lap.minute

Date​

You can create Date from a string or map by calling the function Date. For strings, the date format is specified by the ISO 8601:

YYYY-MM-DD or YYYYMMDD or YYYY-MM

namedescription
YYear
MMonth
DDay

The smallest year is 0 and the highest is 9999.

Example:

CREATE (:Person {birthday : date("1947-07-30")})

For maps, three fields are available: year, month, day.

Example:

CREATE (:Person {birthday: date({year:1947, month:7, day:30})})

You can access the individual fields of a date through its properties:

namedescription
yearReturns the year field
monthReturns the month field
dayReturns the day field

Example:

MATCH (b:Person) RETURN b.birthday.year

LocalTime​

You can create LocalTime from a string or map by calling the function localtime. For strings, the local time format is specified by the ISO 8601:

[T]hh:mm:ss or [T]hh:mm or [T]hhmmss or [T]hhmm or [T]hh

namedescription
hhours
mminutes
sseconds

seconds can be defined as decimal fractions with up to 6 digits. The first 3 digits represent milliseconds and the last 3 digits microseconds. For example the string T22:10:32.300600 specifies 300 milliseconds and 600 microseconds.

Example:

CREATE (:School {Calculus : LocalTime("09:15:00")})

For maps there are 5 fields available: hour, minute, second, millisecond and microsecond.

Example:

CREATE (:School {Calculus : LocalTime({hour:9, minute:15})})

You can access the individual fields of a LocalTime through its properties:

namedescription
hourReturns the hour field
minuteReturns the minute field
secondReturns the second field
millisecondReturns the millisecond field
microsecondReturns the microsecond field

Example:

MATCH (s:School) RETURN s.Calculus.hour

LocalDateTime​

You can create LocalDateTime from a string or map by calling the function localdatetime. For strings, the local time format is specified by the ISO 8601:

YYYY-MM-DDThh:mm:ss or YYYY-MM-DDThh:mm or YYYYMMDDThhmmss or YYYYMMDDThhmm or YYYYMMDDThh

namedescription
YYear
MMonth
DDay
hHours
mMinutes
sSeconds

Example:

CREATE (:Flights {AIR123 : LocalDateTime("2021-10-05T14:15:00")})

For maps the following fields are available: year, month, day, hour, minute, second, millisecond and microsecond

Example:

CREATE (:Flights {AIR123 : LocalDateTime(year:2021, month:10, day:5, hour:14, minute:15)})

You can access the individual fields of LocalDateTime through its properties:

namedescription
yearReturns the year field
monthReturns the month field
dayReturns the day field
hourReturns the hour field
minuteReturns the minute field
secondReturns the second field
millisecondReturns the millisecond field
microsecondReturns the microsecond field

Example:

MATCH (f:Flights) RETURN f.AIR123.year

Temporal types arithmetic​

Temporal types support native arithmetic and the operations are summarized in the following table:

Duration operations:

opresult
duration + durationduration
duration - durationduration
-durationduration

Date operations:

opresult
date + durationdate
duration + datedate
date - durationdate
date - dateduration

LocalTime operations:

opresult
localtime + durationlocaltime
duration + localtimelocaltime
localtime - durationlocaltime
localtime - localtimeduration

LocalDateTime operations:

operationresult
localdatetime + durationlocaldatetime
duration + localdatetime+ localdatetime/
localdatetime - durationlocaldatetime
localdatetime - localdatetimeduration

Procedures API​

Temporal types can also be used within query modules, you can find the documentation on the Pyhon API and C API pages.