Substreams:SQL
The Substreams:SQL Sink allows you to consume the data extracted from the blockchain through a SQL database.
Requirements
Before you begin, make sure you have:
- A Substreams package (for example, a package that indexes ERC20 tokens). 
- A SQL database: Postgres or ClickHouse. 
- The substreams-sink-sql CLI installed in your computer. 
Mapping Substreams to SQL
The core function of the SQL sink is to translate your Substreams output (Protobuf data) into SQL tables. Choose one of the following methods depending on your needs:
- Using Relational Mappings "from-proto" - Enables foreign key relationships in your SQL schema. 
- Requires adding annotations to your Protobuf messages (e.g., primary and foreign keys). 
- Currently insert-only. 
 
- Gives you full control over the output. 
- Supports insert, update, and upsert operations. 
- Ideal for advanced use cases with evolving or mutable data. 
- NOTE: In ClickHouse, reorgs are currently supported with delay. 
 
Relational Mappings
db_out module
SQL relationships
Yes
No
Direct Protobuf<>SQL mappings
Yes
No
INSERT supported
Yes
Yes
UPDATE supported
No
Yes
UPSERT supported
No
Yes
Installation
Enabling substreams-sink-sql in your Substreams CLI.
- Download the current binary, optionally depending on your operating system, from the substreams-sink-sql GitHub releases page. 
- Move the binary to your - $PATH.
Installing from Source
- Clone the substreams-sink-sql GitHub repository. 
- Install the binary using Go. 
go install ./cmd/substreams-sink-sql- Make sure GO is installed and the GO bin directory is in your $PATH. 
Last updated
Was this helpful?

