Subsquid vs The Graph
The Graph is an indexing protocol and framework for EVM chains. In The Graph, indexing projects are called subgraphs. A Graph indexing node is a black-box that executes subgraphs compiled into WASM. The data is sourced directly from an archival blockchain node, and the processed data is stored in a built-in Postgres database.
On the contrary, Subsquid employs a radically open modular architecture with:
- a separated layer for efficient data extraction and batch queries (Subsquid Network)
- a client-side libraries for data transformation and presentation.
The data transformation and presentation is enabled by a growing list of tools and SDKs that consume the raw data from Subsquid Network:
- Typescript based Squid SDK offers pluggable data targets for both online and offline use-cases
- Python-based DipDup SDK
- Subgraphs (via Subsquid Firehose adapter)
- ApeWorx (via ape-subsquid plugin)
Feature matrix
Subsquid Network + Squid SDK | The Graph | |
---|---|---|
Programming language | Typescript | AssemblyScript (compiled to WASM) |
Indexing speed | ~1k-50k bps | ~100-150 bps |
ABI-based generator | Yes | Yes |
Real-time indexing (unfinalized blocks) | Yes | No |
Off-chain data | Yes | No |
Data targets | Customizable | Postgres-only |
Customizable DB migrations | Yes | No |
Factory contract indexing | Yes, via wildcards | Yes |
Multi-contract indexing | Yes | Limited |
Analytic data targets | BigQuery, Parquet, CSV | No |
Local setup | Easy | Requires an archival node |
GraphQL API | Generated from schema.graphql | Generated from schema.graphql |
Custom resolvers and mutations | Yes | No |
Subscriptions | Yes | Via middleware |
Hosted service | Yes | Yes (to be sunset) |
Secret env variables | Yes | No |
Payment | Fiat, subscription-based | GRT, pay-per-query |
Decentralization | Decentralized data sourcing via Subsquid Network, with opt-in decentralized data targets (Kwil DB, Ceramic) and processing (via Lava, in development) | The Graph network |
Architecture difference
By design, The Graph indexing node is a black-box that executes subgraphs compiled into WASM. The data is sourced directly from the archival node and local IPFS, and the processed data is stored in a built-in Postgres database. The data stored in the database is considered to be "sealed", so that no external process can modify or read the data except through the GraphQL interface.