详细分析 ▾
运行时依赖
版本
v2.0.0: Add scripts/ (dune_query.py, dune_discover.py, dune_upload.py), evals/, improved description for better triggering, rewrite usage rules to best practices with explanatory style
安装命令 点击复制
技能文档
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.
⚠️ Usage Rules
- 读取 之前 writing SQL — Select 和 读取 relevant reference files (see Reference Selection) 之前 writing 任何 查询. 做 不 skip step.
- Prefer 私有 Queries — Try
is_private=真第一个. Fall back 到 公开 如果 fails (free plan), 和 notify 用户. - Don't 创建 duplicates — Reuse/更新 existing queries unless explicitly asked 到 创建 新的 ones.
- Confirm 之前 updating — Ask 用户 之前 modifying existing 查询.
- Track credits — 举报 credits consumed 之后 每个 execution. See 查询-execution.md.
Reference Selection
之前 writing 任何 SQL, 路由 到 正确 reference file(s) based 在...上 task:
| Task involves... | Read this reference |
|---|---|
| Finding tables / inspecting schema / discovering protocols | table-discovery.md |
| Finding decoded tables by contract address | table-discovery.md |
| Searching Dune documentation / guides / examples | table-discovery.md |
| Wallet / address tracking / router identification | wallet-analysis.md |
| Table selection / common table names | common-tables.md |
| SQL performance / complex joins / array ops | sql-optimization.md |
| API calls / execution / caching / parameters | query-execution.md |
| Uploading CSV/NDJSON data to Dune | data-upload.md |
Quick 开始
from dune_client.client import DuneClient
from dune_client.query import QueryBase
import osclient = 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
| Method | Description | Plan |
|---|---|---|
run_query | Execute saved query (supports {{param}}) | Free |
run_sql | Execute SQL directly (no params) | Plus |
键 Concepts
dex.trades vs dex_aggregator.trades
| Table | Use Case | Volume |
|---|---|---|
dex.trades | Per-pool analysis | ⚠️ Inflated ~30% (multi-hop counted multiple times) |
dex_aggregator.trades | User/wallet analysis | Accurate |
⚠️ For wallet/address analysis, usedex_aggregator.tradeswithtx_tomatching router addresses fromdune.lz_web3.dataset_crypto_wallet_router. Do not uselabels.allfor wallet router lookups. 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
| Layer | Delay | Example |
|---|---|---|
| Raw | < 1 min | ethereum.transactions, solana.transactions |
| Decoded | 15-60 sec | uniswap_v3_ethereum.evt_Swap |
| Curated | ~1 hour+ | dex.trades, dex_solana.trades |
References
Detailed documentation is organized in the references/ directory:
| File | Description |
|---|---|
| table-discovery.md | Table discovery: search tables by name, inspect schema/columns, list schemas and uploads |
| query-execution.md | API patterns: execute, update, cache, multi-day fetch, credits tracking, subqueries |
| common-tables.md | Quick reference of commonly used tables: raw, decoded, curated, community data |
| sql-optimization.md | SQL optimization: CTE, JOIN strategies, array ops, partition pruning |
| wallet-analysis.md | Wallet tracking: Solana/EVM queries, multi-chain aggregation, fee analysis |
| data-upload.md | Data upload: CSV/NDJSON upload, create table, insert data, manage tables, credits |
免费技能或插件可能存在安全风险,如需更匹配、更安全的方案,建议联系付费定制