dune-analytics-api

Dune Analytics API skill for querying, analyzing, and uploading blockchain data. Use this skill whenever the user mentions Dune, on-chain data, blockchain analytics, token trading volume, DEX activity, wallet tracking, Solana/EVM transaction analysis, or wants to explore crypto data — even if they don't explicitly say 'Dune'. Also use for: running or creating Dune queries, finding blockchain tables and schemas, uploading CSV/NDJSON data to Dune, optimizing SQL for DuneSQL (Trino), checking token prices or trading pairs, analyzing wallet behavior, or any task involving dex.trades, decoded event logs, or raw blockchain transactions. Triggers on: Dune, blockchain data, on-chain, DEX trades, token volume, Solana transactions, wallet analysis, query optimization, data upload, table discovery, contract address lookup, crypto analytics, DuneSQL.

Safety Notice

This listing is from the official public ClawHub registry. Review SKILL.md and referenced scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "dune-analytics-api" with this command: npx skills add LZ-Web3/dune-analytics-api

Dune Analytics API

A skill for querying and analyzing blockchain data via the Dune Analytics API.

Setup

pip install dune-client

Set DUNE_API_KEY via environment variable, .env file, or agent config.

Best Practices

  1. Read references first — The reference files contain critical table names, anti-patterns, and chain-specific gotchas that aren't obvious from table names alone. Reading the right reference before writing SQL prevents common mistakes like using dex.trades for wallet analysis (which inflates volume ~30%) or missing Solana's dedup requirement.

  2. Prefer private queries — Creating queries with is_private=True keeps the user's workspace clean and avoids polluting the public Dune namespace. Fall back to public if it fails (free plan limitation), and let the user know.

  3. Reuse before creating — Dune charges credits per execution. Reusing or updating an existing query avoids unnecessary duplicates and makes credit tracking easier. Only create new queries when the user explicitly asks.

  4. Confirm before updating — Modifying an existing query's SQL is destructive (previous version isn't saved by default). A quick confirmation avoids overwriting work the user might want to keep.

  5. Track credits — Each execution costs credits depending on the performance tier and data scanned. Reporting credits consumed helps the user manage their budget. See query-execution.md.

Scripts — Common Operations

For common operations, use the scripts in scripts/ to avoid writing boilerplate code every time. All scripts read DUNE_API_KEY from the environment automatically.

ScriptCommandWhat it does
dune_query.pyexecute --query-id IDExecute a saved query (supports --params, --performance, --format)
dune_query.pyget_latest --query-id IDGet cached result without re-execution
dune_query.pyget_sql --query-id IDPrint query SQL
dune_query.pyupdate_sql --query-id ID --sql "..."Update query SQL
dune_discover.pysearch --keyword "uniswap"Search tables by keyword
dune_discover.pyschema --table "dex.trades"Show table columns and types
dune_discover.pylist_schemas --namespace "uniswap_v3"List tables in a namespace
dune_discover.pycontract --address "0x..."Find decoded tables by contract address
dune_discover.pydocs --keyword "dex"Search Dune documentation
dune_upload.pyupload_csv --file data.csv --table-name tblQuick CSV upload (overwrites)
dune_upload.pycreate_table --table-name tbl --namespace ns --schema '[...]'Create table with explicit schema
dune_upload.pyinsert --file data.csv --table-name tbl --namespace nsAppend data to existing table

Example:

# Execute query with parameters
python scripts/dune_query.py execute --query-id 123456 --params '{"token":"ETH"}' --format table

# Upload a CSV privately
python scripts/dune_upload.py upload_csv --file wallets.csv --table-name my_wallets --private

Reference Selection

Before writing any SQL, route to the correct reference file(s) based on your task:

Task involves...Read this reference
Finding tables / inspecting schema / discovering protocolstable-discovery.md
Finding decoded tables by contract addresstable-discovery.md
Searching Dune documentation / guides / examplestable-discovery.md
Wallet / address tracking / router identificationwallet-analysis.md
Table selection / common table namescommon-tables.md
SQL performance / complex joins / array opssql-optimization.md
API calls / execution / caching / parametersquery-execution.md
Uploading CSV/NDJSON data to Dunedata-upload.md

If your task spans multiple categories, read all relevant files. The references contain critical details (e.g., specialized tables, anti-patterns) that aren't covered in this overview — guessing table names or query patterns leads to subtle bugs.

Quick Start

from dune_client.client import DuneClient
from dune_client.query import QueryBase
import os

client = DuneClient(api_key=os.environ['DUNE_API_KEY'])

# Execute a query
result = client.run_query(query=QueryBase(query_id=123456), performance='medium', ping_frequency=5)
print(f"Rows: {len(result.result.rows)}")

# Get cached result (no re-execution)
result = client.get_latest_result(query_id=123456)

# Get/update SQL
sql = client.get_query(123456).sql
client.update_query(query_id=123456, query_sql="SELECT ...")

# Upload CSV data (quick, overwrites existing)
client.upload_csv(
    data="col1,col2\nval1,val2",
    description="My data",
    table_name="my_table",
    is_private=True
)

# Create table + insert (supports append)
client.create_table(
    namespace="my_user",
    table_name="my_table",
    schema=[{"name": "col1", "type": "varchar"}, {"name": "col2", "type": "double"}],
    is_private=True
)
import io
client.insert_data(
    namespace="my_user",
    table_name="my_table",
    data=io.BytesIO(b"col1,col2\nabc,1.5"),
    content_type="text/csv"
)

Subscription Tiers

MethodDescriptionPlan
run_queryExecute saved query (supports {{param}})Free
run_sqlExecute SQL directly (no params)Plus

Key Concepts

dex.trades vs dex_aggregator.trades

TableUse CaseVolume
dex.tradesPer-pool analysis⚠️ Inflated ~30% (multi-hop counted multiple times)
dex_aggregator.tradesUser/wallet analysisAccurate

Why this matters: If you're analyzing a specific wallet's trading activity and use dex.trades, you'll see inflated volume because a single swap through an aggregator gets split into multiple pool-level trades. dex_aggregator.trades captures the user-level intent — one row per user swap. See wallet-analysis.md for full patterns.

Solana has no dex_aggregator_solana.trades. Dedupe by tx_id:

SELECT tx_id, MAX(amount_usd) as amount_usd
FROM dex_solana.trades
GROUP BY tx_id

Data Freshness

LayerDelayExample
Raw< 1 minethereum.transactions, solana.transactions
Decoded15-60 secuniswap_v3_ethereum.evt_Swap
Curated~1 hour+dex.trades, dex_solana.trades

Query previous day's data after UTC 12:00 for completeness.

References

Detailed documentation is organized in the references/ directory:

FileDescription
table-discovery.mdTable discovery: search tables by name, inspect schema/columns, list schemas and uploads
query-execution.mdAPI patterns: execute, update, cache, multi-day fetch, credits tracking, subqueries
common-tables.mdQuick reference of commonly used tables: raw, decoded, curated, community data
sql-optimization.mdSQL optimization: CTE, JOIN strategies, array ops, partition pruning
wallet-analysis.mdWallet tracking: Solana/EVM queries, multi-chain aggregation, fee analysis
data-upload.mdData upload: CSV/NDJSON upload, create table, insert data, manage tables, credits

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Web3

PredictClash

Predict Clash - join prediction rounds on crypto prices and stock indices for PP rewards. Server assigns unpredicted questions, you analyze and submit. Use w...

Registry SourceRecently Updated
Web3

Crypto Holdings Monitor

加密货币持仓监控工具。支持多钱包地址监控、实时价格查询、持仓统计。

Registry SourceRecently Updated
Web3

OpenClaw News Watcher

Monitors CoinDesk or PANews for new crypto articles, summarizes them, and sends updates to Telegram without API keys or login.

Registry SourceRecently Updated