CARVIEW |
Select Language
HTTP/2 200
date: Thu, 31 Jul 2025 12:02:43 GMT
content-type: text/html; charset=utf-8
nel: {"report_to":"cf-nel","success_fraction":0.0,"max_age":604800}
server: cloudflare
last-modified: Thu, 31 Jul 2025 07:10:01 GMT
access-control-allow-origin: *
expires: Thu, 31 Jul 2025 12:12:43 GMT
cache-control: max-age=600
report-to: {"group":"cf-nel","max_age":604800,"endpoints":[{"url":"https://a.nel.cloudflare.com/report/v4?s=cMPvmZ2aSMrBQXO62o9MOp99jF6j1LpAVJW4OrgTOQz85Zox38wdEFb4mDovyNByoGLArNonEHR8swW7vVZX1LvvJAbBp9bV3A%3D%3D"}]}
x-proxy-cache: MISS
x-github-request-id: 9878:229458:8D244:A5B22:688B5B63
age: 0
via: 1.1 varnish
x-served-by: cache-maa10234-MAA
x-cache: MISS
x-cache-hits: 0
x-timer: S1753963363.259311,VS0,VE231
vary: Accept-Encoding
x-fastly-request-id: 3e6a73d7070691de32ad6e5c65998527dbf60d75
cf-cache-status: DYNAMIC
content-encoding: gzip
cf-ray: 967cf2cc3a108839-BLR
alt-svc: h3=":443"; ma=86400
Interval Functions – DuckDB
Search Shortcut cmd + k | ctrl + k
- 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
- ADBC
- C
- Overview
- Startup
- Configuration
- Query
- Data Chunks
- Vectors
- Values
- Types
- Prepared Statements
- Appender
- Table Functions
- Replacement Scans
- API Reference
- C++
- CLI
- Dart
- Go
- Java (JDBC)
- Julia
- Node.js (Deprecated)
- Node.js (Neo)
- ODBC
- PHP
- 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
- 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
- LOAD / INSTALL
- PIVOT
- Profiling
- SELECT
- SET / RESET
- SET VARIABLE
- SUMMARIZE
- Transaction Management
- UNPIVOT
- UPDATE
- USE
- VACUUM
- 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 Expression
- Casting
- Collations
- Comparisons
- IN Operator
- Logical Operators
- Star Expression
- Subqueries
- TRY
- 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
- Overview
- Indexing
- Friendly SQL
- Keywords and Identifiers
- Order Preservation
- PostgreSQL Compatibility
- SQL Quirks
- Samples
- Configuration
- Extensions
- Overview
- Installing Extensions
- Advanced Installation Methods
- Distributing Extensions
- Versioning of Extensions
- Troubleshooting of Extensions
- Core Extensions
- Overview
- AutoComplete
- Avro
- AWS
- Azure
- Delta
- DuckLake
- Encodings
- Excel
- Full Text Search
- httpfs (HTTP and S3)
- Iceberg
- Overview
- Iceberg REST Catalogs
- Amazon S3 Tables
- Amazon SageMaker Lakehouse (AWS Glue)
- Troubleshooting
- ICU
- inet
- jemalloc
- MySQL
- PostgreSQL
- Spatial
- SQLite
- TPC-DS
- TPC-H
- UI
- 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
- File Access with the file: Protocol
- 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
- Fastly Object Storage Import
- 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
- Working with Huge Databases
- Python
- Installation
- Executing SQL
- Jupyter Notebooks
- marimo 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
- Creating Synthetic Data
- Dutch Railway Datasets
- Sharing Macros
- Analyzing a Git Repository
- Importing Duckbox Tables
- Copying an In-Memory Database to a File
- Troubleshooting
- Glossary of Terms
- Browsing Offline
- Operations Manual
- Overview
- DuckDB's Footprint
- Logging
- Securing DuckDB
- Non-Deterministic Behavior
- Limits
- Development
- DuckDB Repositories
- Profiling
- Building DuckDB
- Overview
- Build Configuration
- Building Extensions
- Android
- Linux
- macOS
- Raspberry Pi
- Windows
- Python
- R
- Troubleshooting
- Unofficial and Unsupported Platforms
- Benchmark Suite
- Testing
- Internals
- Why DuckDB
- Code of Conduct
- Release Calendar
- Roadmap
- Sitemap
- Live Demo
Documentation
/ SQL
/ Functions
Interval Functions
This section describes functions and operators for examining and manipulating INTERVAL
values.
Interval Operators
The table below shows the available mathematical operators for INTERVAL
types.
Operator | Description | Example | Result |
---|---|---|---|
+ |
Addition of an INTERVAL |
INTERVAL 1 HOUR + INTERVAL 5 HOUR |
INTERVAL 6 HOUR |
+ |
Addition to a DATE |
DATE '1992-03-22' + INTERVAL 5 DAY |
1992-03-27 |
+ |
Addition to a TIMESTAMP |
TIMESTAMP '1992-03-22 01:02:03' + INTERVAL 5 DAY |
1992-03-27 01:02:03 |
+ |
Addition to a TIME |
TIME '01:02:03' + INTERVAL 5 HOUR |
06:02:03 |
- |
Subtraction of an INTERVAL |
INTERVAL 5 HOUR - INTERVAL 1 HOUR |
INTERVAL 4 HOUR |
- |
Subtraction from a DATE |
DATE '1992-03-27' - INTERVAL 5 DAY |
1992-03-22 |
- |
Subtraction from a TIMESTAMP |
TIMESTAMP '1992-03-27 01:02:03' - INTERVAL 5 DAY |
1992-03-22 01:02:03 |
- |
Subtraction from a TIME |
TIME '06:02:03' - INTERVAL 5 HOUR |
01:02:03 |
Interval Functions
The table below shows the available scalar functions for INTERVAL
types.
Name | Description |
---|---|
date_part(part, interval) |
Extract datepart component (equivalent to extract ). See INTERVAL for the sometimes surprising rules governing this extraction. |
datepart(part, interval) |
Alias of date_part . |
extract(part FROM interval) |
Alias of date_part . |
epoch(interval) |
Get total number of seconds, as double precision floating point number, in interval. |
to_centuries(integer) |
Construct a century interval. |
to_days(integer) |
Construct a day interval. |
to_decades(integer) |
Construct a decade interval. |
to_hours(integer) |
Construct an hour interval. |
to_microseconds(integer) |
Construct a microsecond interval. |
to_millennia(integer) |
Construct a millennium interval. |
to_milliseconds(integer) |
Construct a millisecond interval. |
to_minutes(integer) |
Construct a minute interval. |
to_months(integer) |
Construct a month interval. |
to_quarters(integer ) |
Construct an interval of integer quarters. |
to_seconds(integer) |
Construct a second interval. |
to_weeks(integer) |
Construct a week interval. |
to_years(integer) |
Construct a year interval. |
Only the documented date part components are defined for intervals.
date_part(part, interval)
Description | Extract datepart component (equivalent to extract ). See INTERVAL for the sometimes surprising rules governing this extraction. |
Example | date_part('year', INTERVAL '14 months') |
Result | 1 |
datepart(part, interval)
Description | Alias of date_part . |
Example | datepart('year', INTERVAL '14 months') |
Result | 1 |
extract(part FROM interval)
Description | Alias of date_part . |
Example | extract('month' FROM INTERVAL '14 months') |
Result | 2 |
epoch(interval)
Description | Get total number of seconds, as double precision floating point number, in interval. |
Example | epoch(INTERVAL 5 HOUR) |
Result | 18000.0 |
to_centuries(integer)
Description | Construct a century interval. |
Example | to_centuries(5) |
Result | INTERVAL 500 YEAR |
to_days(integer)
Description | Construct a day interval. |
Example | to_days(5) |
Result | INTERVAL 5 DAY |
to_decades(integer)
Description | Construct a decade interval. |
Example | to_decades(5) |
Result | INTERVAL 50 YEAR |
to_hours(integer)
Description | Construct an hour interval. |
Example | to_hours(5) |
Result | INTERVAL 5 HOUR |
to_microseconds(integer)
Description | Construct a microsecond interval. |
Example | to_microseconds(5) |
Result | INTERVAL 5 MICROSECOND |
to_millennia(integer)
Description | Construct a millennium interval. |
Example | to_millennia(5) |
Result | INTERVAL 5000 YEAR |
to_milliseconds(integer)
Description | Construct a millisecond interval. |
Example | to_milliseconds(5) |
Result | INTERVAL 5 MILLISECOND |
to_minutes(integer)
Description | Construct a minute interval. |
Example | to_minutes(5) |
Result | INTERVAL 5 MINUTE |
to_months(integer)
Description | Construct a month interval. |
Example | to_months(5) |
Result | INTERVAL 5 MONTH |
to_quarters(integer)
Description | Construct an interval of integer quarters. |
Example | to_quarters(5) |
Result | INTERVAL 1 YEAR 3 MONTHS |
to_seconds(integer)
Description | Construct a second interval. |
Example | to_seconds(5) |
Result | INTERVAL 5 SECOND |
to_weeks(integer)
Description | Construct a week interval. |
Example | to_weeks(5) |
Result | INTERVAL 35 DAY |
to_years(integer)
Description | Construct a year interval. |
Example | to_years(5) |
Result | INTERVAL 5 YEAR |