FQL v4 will be decommissioned on June 30, 2025. Ensure that you complete your migration from FQL v4 to FQL v10 by that date.

Fauna accounts created after August 21, 2024 must use FQL v10. These accounts will not be able to run FQL v4 queries or access the v4 Dashboard.

For more details, see the v4 EOL announcement and migration guide. Contact support@fauna.com with any questions.

TimeAdd

This reference topic applies to FQL v4. Go to this page for the latest FQL v10 reference topics.

TimeAdd( base, offset, unit )
time_add( base, offset, unit )
TimeAdd( base, offset, unit )
TimeAdd( base, offset, unit )
TimeAdd( base, offset, unit )
TimeAdd( base, offset, unit )

Description

The TimeAdd function increases a base Timestamp or Date by adding the offset in units.

Parameters

Parameter Type Definition and Requirements

base

Timestamp or Date

A timestamp or date to add to. base must match the type of unit.

offset

Integer or Long

The integer number of units to add to base.

unit

String

Unit of the offset.

When base is a Date, unit must be one of day or days.

When base is a Timestamp, unit must be one of:

  • day, or days

  • half day, or half days

  • hour, or hours

  • minute, or minutes

  • second, or seconds

  • millisecond, or milliseconds

  • microsecond, or microseconds

  • nanosecond, or nanoseconds

Returns

When base is a Date, a new Date which represents base with offset units added to it.

When base is a Timestamp, a new Timestamp which represents base with offset units added to it.

Examples

The following query returns a Timestamp representing one day after the Unix epoch:

client.query(
  q.TimeAdd(q.Epoch(0, 'second'), 1, 'day')
)
.then((ret) => console.log(ret))
.catch((err) => console.error(
  'Error: [%s] %s: %s',
  err.name,
  err.message,
  err.errors()[0].description,
))
Time("1970-01-02T00:00:00Z")
result = client.query(
  q.time_add(q.epoch(1, "day"), 1, "second")
)
print(result)
FaunaTime('1970-01-02T00:00:01Z')
result, err := client.Query(
	f.TimeAdd(f.Epoch(1, "day"), 1, "second"))

if err != nil {
	fmt.Fprintln(os.Stderr, err)
} else {
	fmt.Println(result)
}
{0 62135683201 <nil>}
try
{
    Value result = await client.Query(
        TimeAdd(Epoch(0, "second"), 1, "day")
    );

    Console.WriteLine(result);
}
catch (Exception e)
{
    Console.WriteLine($"ERROR: {e.Message}");
}
FaunaTime(1970-01-02T00:00:00Z)
System.out.println(
    client.query(
        TimeAdd(Epoch(0, "second"), 1, "day")
    ).get());
1970-01-02T00:00:00Z
TimeAdd(Epoch(0, 'second'), 1, 'day')
Time("1970-01-02T00:00:00Z")
Query metrics:
  •    bytesIn:  64

  •   bytesOut:  43

  • computeOps:   1

  •    readOps:   0

  •   writeOps:   0

  •  readBytes:   0

  • writeBytes:   0

  •  queryTime: 3ms

  •    retries:   0

The following query returns a Timestamp 5 seconds in the future from now:

client.query([
  q.Now(),
  q.TimeAdd(q.Now(), 5, 'seconds'),
])
.then((ret) => console.log(ret))
.catch((err) => console.error(
  'Error: [%s] %s: %s',
  err.name,
  err.message,
  err.errors()[0].description,
))
[ Time("2019-10-22T16:45:19.223863Z"),
  Time("2019-10-22T16:45:24.223863Z") ]
result = client.query(
  [
    q.now(),
    q.time_add(q.now(), 5, "seconds"),
  ]
)
print(result)
[FaunaTime('2021-01-18T22:04:09.121Z'), FaunaTime('2021-01-18T22:04:14.121Z')]
result, err := client.Query(
	f.Arr{
		f.Now(),
		f.TimeAdd(f.Now(), 5, "seconds"),
	})

if err != nil {
	fmt.Fprintln(os.Stderr, err)
} else {
	fmt.Println(result)
}
[{183000000 63746604242 <nil>} {183000000 63746604247 <nil>}]
try
{
    Value result = await client.Query(
        Arr(
            Now(),
            TimeAdd(Now(), 5, "seconds")
        )
    );

    Console.WriteLine(result);
}
catch (Exception e)
{
    Console.WriteLine($"ERROR: {e.Message}");
}
Arr(FaunaTime(2019-10-22T16:45:15.23Z), FaunaTime(2019-10-22T16:45:20.23Z))
System.out.println(
    client.query(
        Arr(
            Time("2020-07-06T12:34:56.789Z"),
            TimeAdd(Time("2020-07-06T12:34:56.789Z"), 5, "seconds")
        )
    ).get());
[2020-07-06T12:34:56.789Z, 2020-07-06T12:35:01.789Z]
[
  Now(),
  TimeAdd(Now(), 5, 'seconds')
]
[ Time("2021-06-23T12:23:09.348Z"), Time("2021-06-23T12:23:14.348Z") ]
Query metrics:
  •    bytesIn:  68

  •   bytesOut:  84

  • computeOps:   1

  •    readOps:   0

  •   writeOps:   0

  •  readBytes:   0

  • writeBytes:   0

  •  queryTime: 2ms

  •    retries:   0

The following query returns a Date 1 day after 2019-11-26:

client.query(
  q.TimeAdd(q.Date('2019-11-26'), 1, 'day')
)
.then((ret) => console.log(ret))
.catch((err) => console.error(
  'Error: [%s] %s: %s',
  err.name,
  err.message,
  err.errors()[0].description,
))
Date("2019-11-27")
result = client.query(
  q.time_add(q.date("2019-11-26"), 1, "day")
)
print(result)
2019-11-27
result, err := client.Query(
	f.TimeAdd(f.Date("2019-11-26"), 1, "day"))

if err != nil {
	fmt.Fprintln(os.Stderr, err)
} else {
	fmt.Println(result)
}
{0 63710409600 <nil>}
try
{
    Value result = await client.Query(
        TimeAdd(Date("2019-11-26"), 1, "day")
    );

    Console.WriteLine(result);
}
catch (Exception e)
{
    Console.WriteLine($"ERROR: {e.Message}");
}
FaunaDate(2019-11-27 12:00:00 AM)
System.out.println(
    client.query(
        TimeAdd(Date("2019-11-26"), 1, "day")
    ).get());
2019-11-27
TimeAdd(Date('2019-11-26'), 1, 'day')
Date("2019-11-27")
Query metrics:
  •    bytesIn:  58

  •   bytesOut:  35

  • computeOps:   1

  •    readOps:   0

  •   writeOps:   0

  •  readBytes:   0

  • writeBytes:   0

  •  queryTime: 2ms

  •    retries:   0

Is this article helpful? 

Tell Fauna how the article can be improved:
Visit Fauna's forums or email docs@fauna.com

Thank you for your feedback!