Dune API Overview
Endpoints
- Query metadata: `GET /api/v1/query/{id}`
- name, description, tags, version, parameters (types, defaults), query_sql
- Execute query: `POST /api/v1/query/{id}/execute`
- body: { query_parameters?: object, performance?: 'medium'|'large' }
- returns: { execution_id }
- Execution status: `GET /api/v1/execution/{execution_id}/status`
- fields: is_execution_finished, state, execution_started_at, execution_ended_at
- Results (JSON): `GET /api/v1/query/{id}/results?limit=&offset=&sort_by=&columns=&sample_count=`
- top-level: execution_id, is_execution_finished, state, submitted_at, expires_at, execution_started_at, execution_ended_at
- result.rows[]: array of objects
- result.metadata: { column_names[], column_types[], row_count, total_row_count, ... }
- pagination: next_uri, next_offset (when more rows available)
- Results (CSV): `GET /api/v1/query/{id}/results/csv?...`
- pagination headers: `x-dune-next-uri`, `x-dune-next-offset`, `Link: rel="next"`
Parameters
- query_parameters: object — pass SQL parameters defined in the query (text/number/datetime/enum)
- performance: 'medium' | 'large' — server-side execution hint
- limit, offset: row paging; sample_count: random sample of rows; sort_by, columns: server-side projection and ordering
Status & Errors
- Poll status until is_execution_finished or failure state (QUERY_STATE_FAILED)
- Rate limiting: HTTP 429 with backoff recommended
- No latest execution: JSON error message indicates none exists for latest version
Metadata-First Planning
- Use JSON results endpoint with limit=0 to fetch `result.metadata` quickly (row counts and column names/types) before fetching data.
Raw SQL Support
- spice-mcp uses an internal dynamic query mechanism to evaluate raw SQL via Dune (by binding into a parameterized template), enabling quick ad-hoc exploration.