- Installation
- Documentation
- Getting Started
- Connect
- Data Import
- Overview
- Data Sources
- CSV Files
- JSON Files
- Overview
- Creating JSON
- Loading JSON
- Writing JSON
- JSON Type
- JSON Functions
- Format Settings
- Installing and Loading
- SQL to / from JSON
- Caveats
- Multiple Files
- Parquet Files
- Partitioning
- Appender
- INSERT Statements
- Client APIs
- Overview
- C
- Overview
- Startup
- Configuration
- Query
- Data Chunks
- Vectors
- Values
- Types
- Prepared Statements
- Appender
- Table Functions
- Replacement Scans
- API Reference
- C++
- CLI
- Dart
- Go
- Java
- Julia
- Node.js (Neo)
- Node.js
- Python
- Overview
- Data Ingestion
- Conversion between DuckDB and Python
- DB API
- Relational API
- Function API
- Types API
- Expression API
- Spark API
- API Reference
- Known Python Issues
- R
- Rust
- Swift
- Wasm
- ADBC
- ODBC
- SQL
- Introduction
- Statements
- Overview
- ANALYZE
- ALTER TABLE
- ALTER VIEW
- ATTACH and DETACH
- CALL
- CHECKPOINT
- COMMENT ON
- COPY
- CREATE INDEX
- CREATE MACRO
- CREATE SCHEMA
- CREATE SECRET
- CREATE SEQUENCE
- CREATE TABLE
- CREATE VIEW
- CREATE TYPE
- DELETE
- DESCRIBE
- DROP
- EXPORT and IMPORT DATABASE
- INSERT
- PIVOT
- Profiling
- SELECT
- SET / RESET
- SET VARIABLE
- SUMMARIZE
- Transaction Management
- UNPIVOT
- UPDATE
- USE
- VACUUM
- LOAD / INSTALL
- Query Syntax
- SELECT
- FROM and JOIN
- WHERE
- GROUP BY
- GROUPING SETS
- HAVING
- ORDER BY
- LIMIT and OFFSET
- SAMPLE
- Unnesting
- WITH
- WINDOW
- QUALIFY
- VALUES
- FILTER
- Set Operations
- Prepared Statements
- Data Types
- Overview
- Array
- Bitstring
- Blob
- Boolean
- Date
- Enum
- Interval
- List
- Literal Types
- Map
- NULL Values
- Numeric
- Struct
- Text
- Time
- Timestamp
- Time Zones
- Union
- Typecasting
- Expressions
- Overview
- CASE Statement
- Casting
- Collations
- Comparisons
- IN Operator
- Logical Operators
- Star Expression
- Subqueries
- Functions
- Overview
- Aggregate Functions
- Array Functions
- Bitstring Functions
- Blob Functions
- Date Format Functions
- Date Functions
- Date Part Functions
- Enum Functions
- Interval Functions
- Lambda Functions
- List Functions
- Map Functions
- Nested Functions
- Numeric Functions
- Pattern Matching
- Regular Expressions
- Struct Functions
- Text Functions
- Time Functions
- Timestamp Functions
- Timestamp with Time Zone Functions
- Union Functions
- Utility Functions
- Window Functions
- Constraints
- Indexes
- Meta Queries
- DuckDB's SQL Dialect
- Samples
- Configuration
- Extensions
- Overview
- Core Extensions
- Community Extensions
- Working with Extensions
- Versioning of Extensions
- Arrow
- AutoComplete
- AWS
- Azure
- Delta
- Excel
- Full Text Search
- httpfs (HTTP and S3)
- Iceberg
- ICU
- inet
- jemalloc
- MySQL
- PostgreSQL
- Spatial
- SQLite
- Substrait
- TPC-DS
- TPC-H
- VSS
- Guides
- Overview
- Data Viewers
- Database Integration
- File Formats
- Overview
- CSV Import
- CSV Export
- Directly Reading Files
- Excel Import
- Excel Export
- JSON Import
- JSON Export
- Parquet Import
- Parquet Export
- Querying Parquet Files
- Network and Cloud Storage
- Overview
- HTTP Parquet Import
- S3 Parquet Import
- S3 Parquet Export
- S3 Iceberg Import
- S3 Express One
- GCS Import
- Cloudflare R2 Import
- DuckDB over HTTPS / S3
- Meta Queries
- Describe Table
- EXPLAIN: Inspect Query Plans
- EXPLAIN ANALYZE: Profile Queries
- List Tables
- Summarize
- DuckDB Environment
- ODBC
- Performance
- Overview
- Environment
- Import
- Schema
- Indexing
- Join Operations
- File Formats
- How to Tune Workloads
- My Workload Is Slow
- Benchmarks
- Python
- Installation
- Executing SQL
- Jupyter Notebooks
- SQL on Pandas
- Import from Pandas
- Export to Pandas
- Import from Numpy
- Export to Numpy
- SQL on Arrow
- Import from Arrow
- Export to Arrow
- Relational API on Pandas
- Multiple Python Threads
- Integration with Ibis
- Integration with Polars
- Using fsspec Filesystems
- SQL Editors
- SQL Features
- Snippets
- Glossary of Terms
- Browse Offline
- Operations Manual
- Overview
- Limits
- Non-Deterministic Behavior
- Embedding DuckDB
- DuckDB's Footprint
- Securing DuckDB
- Development
- DuckDB Repositories
- Testing
- Overview
- sqllogictest Introduction
- Writing Tests
- Debugging
- Result Verification
- Persistent Testing
- Loops
- Multiple Connections
- Catch
- Profiling
- Release Calendar
- Building
- Benchmark Suite
- Internals
- Sitemap
- Why DuckDB
- Media
- FAQ
- Code of Conduct
- Live Demo
Timestamps represent points in absolute time, usually called instants.
DuckDB represents instants as the number of microseconds (µs) (or nanoseconds, for TIMESTAMP_NS
) since 1970-01-01 00:00:00+00
.
Timestamp Types
Name | Aliases | Description |
---|---|---|
TIMESTAMP_NS |
timestamp with nanosecond precision (ignores time zone) | |
TIMESTAMP |
DATETIME |
timestamp with microsecond precision (ignores time zone) |
TIMESTAMP_MS |
timestamp with millisecond precision (ignores time zone) | |
TIMESTAMP_S |
timestamp with second precision (ignores time zone) | |
TIMESTAMPTZ |
TIMESTAMP WITH TIME ZONE |
timestamp with microsecond precision (uses time zone) |
A timestamp specifies a combination of DATE
(year, month, day) and a TIME
(hour, minute, second, microsecond or nanosecond). Timestamps can be created using the TIMESTAMP
keyword, where the data must be formatted according to the ISO 8601 format (YYYY-MM-DD hh:mm:ss[.zzzzzz][+-TT[:tt]]
(three extra decimal places supported by TIMESTAMP_NS
). Decimal places beyond the targeted sub-second precision are ignored.
Since there is not currently a
TIMESTAMP_NS WITH TIME ZONE
data type, external columns with nano-second precision and "instant semantics", e.g., parquet timestamp columns withisAdjustedToUTC=true
, lose precision when read using DuckDB.
SELECT TIMESTAMP_NS '1992-09-20 11:30:00.123456789';
1992-09-20 11:30:00.123456789
SELECT TIMESTAMP '1992-09-20 11:30:00.123456789';
1992-09-20 11:30:00.123456
SELECT DATETIME '1992-09-20 11:30:00.123456789';
1992-09-20 11:30:00.123456
SELECT TIMESTAMP_MS '1992-09-20 11:30:00.123456789';
1992-09-20 11:30:00.123
SELECT TIMESTAMP_S '1992-09-20 11:30:00.123456789';
1992-09-20 11:30:00
SELECT TIMESTAMPTZ '1992-09-20 11:30:00.123456789';
1992-09-20 11:30:00.123456+00
SELECT TIMESTAMP WITH TIME ZONE '1992-09-20 11:30:00.123456789';
1992-09-20 11:30:00.123456+00
Special Values
There are also three special date values that can be used on input:
Input string | Valid types | Description |
---|---|---|
epoch |
TIMESTAMP , TIMESTAMPTZ |
1970-01-01 00:00:00+00 (Unix system time zero) |
infinity |
TIMESTAMP , TIMESTAMPTZ |
later than all other time stamps |
-infinity |
TIMESTAMP , TIMESTAMPTZ |
earlier than all other time stamps |
The values infinity
and -infinity
are specially represented inside the system and will be displayed unchanged;
but epoch
is simply a notational shorthand that will be converted to the time stamp value when read.
SELECT '-infinity'::TIMESTAMP, 'epoch'::TIMESTAMP, 'infinity'::TIMESTAMP;
Negative | Epoch | Positive |
---|---|---|
-infinity | 1970-01-01 00:00:00 | infinity |
Functions
See Timestamp Functions.
Time Zones
The TIMESTAMPTZ
type can be binned into calendar and clock bins using a suitable extension.
The built-in ICU extension implements all the binning and arithmetic functions using the
International Components for Unicode time zone and calendar functions.
To set the time zone to use, first load the ICU extension. The ICU extension comes pre-bundled with several DuckDB clients (including Python, R, JDBC, and ODBC), so this step can be skipped in those cases. In other cases you might first need to install and load the ICU extension.
INSTALL icu;
LOAD icu;
Next, use the SET TimeZone
command:
SET TimeZone = 'America/Los_Angeles';
Time binning operations for TIMESTAMPTZ
will then be implemented using the given time zone.
A list of available time zones can be pulled from the pg_timezone_names()
table function:
SELECT
name,
abbrev,
utc_offset
FROM pg_timezone_names()
ORDER BY
name;
You can also find a reference table of available time zones.
Calendars
The ICU extension also supports non-Gregorian calendars using the SET Calendar
command.
Note that the INSTALL
and LOAD
steps are only required if the DuckDB client does not bundle the ICU extension.
INSTALL icu;
LOAD icu;
SET Calendar = 'japanese';
Time binning operations for TIMESTAMPTZ
will then be implemented using the given calendar.
In this example, the era
part will now report the Japanese imperial era number.
A list of available calendars can be pulled from the icu_calendar_names()
table function:
SELECT name
FROM icu_calendar_names()
ORDER BY 1;
Settings
The current value of the TimeZone
and Calendar
settings are determined by ICU when it starts up.
They can be queried from in the duckdb_settings()
table function:
SELECT *
FROM duckdb_settings()
WHERE name = 'TimeZone';
name | value | description | input_type |
---|---|---|---|
TimeZone | Europe/Amsterdam | The current time zone | VARCHAR |
SELECT *
FROM duckdb_settings()
WHERE name = 'Calendar';
name | value | description | input_type |
---|---|---|---|
Calendar | gregorian | The current calendar | VARCHAR |