solana.core Table: fact_sol_daily_balances Type: Base Table
View DBT Documentation
View the complete technical documentation and data lineage for this table
Description
This table provides daily snapshots of native SOL balances for each account on the Solana blockchain. It creates a complete daily time series by forward-filling the most recent balance when thereās no activity on a given day, ensuring every account has a balance record for each date since their first transaction. When multiple balance updates occur within a day, only the last balance is retained. The table tracks native SOL only (mint address: So11111111111111111111111111111111111111111). Important: If an account is left with a 0 balance at the end of the day, it is not included in the table. This means accounts will ādisappearā from the daily snapshots when their balance reaches zero and āreappearā when they receive SOL again.Key Use Cases
- Daily balance analysis: Track SOL holdings over time for accounts, wallets, and protocols
- Portfolio tracking: Monitor SOL balance changes and trends for specific addresses
- Whale watching: Identify large SOL holders and track their balance movements
- Protocol analysis: Analyze SOL reserves and treasury balances for DeFi protocols
- Time series analytics: Perform historical balance analysis and trend identification
- Snapshot reporting: Generate point-in-time balance reports for any historical date
Important Relationships
- Sources data from
core.fact_sol_balanceswhich contains all SOL balance changes - Uses
crosschain.core.dim_datesfor generating complete daily time series - Complements
core.fact_token_daily_balanceswhich handles SPL token balances - Related to
core.ez_transfersfor understanding SOL movement patterns
Commonly-used Fields
balance_date: Essential for time-based analysis and filtering to specific datesaccount: Core field for account-specific balance tracking and wallet analysisamount: The SOL balance amount (in decimal SOL, not lamports) for value calculationslast_balance_change: Critical for understanding when balances were last updated (only tracks dates when account had a positive balance)balance_changed_on_date: Key for filtering to only dates with actual balance activity
Sample Queries
Get current SOL balance for a specific account
Track SOL balance changes over time for an account
Find accounts with largest SOL balances on a specific date
Analyze SOL balance distribution
Columns
| Column Name | Data Type | Description |
|---|---|---|
| BALANCE_DATE | DATE | The date for which the balance snapshot is recorded. This field represents the calendar date (in UTC) for the daily balance record, providing the time dimension for balance analysis. |
| ACCOUNT | TEXT | The base58-encoded address of the account holding the asset. For native SOL, this is the wallet address. Used to attribute balances and transfers to specific accounts. |
| AMOUNT | FLOAT | The accountās balance after the transaction, decimal-adjusted. For SOL, this is in units of SOL (not lamports). |
| LAST_BALANCE_CHANGE | DATE | The date when this account last had an actual balance change that resulted in a positive balance. This field tracks the most recent date when the balance was modified to a positive amount, which may be earlier than the balance_date due to forward-filling of balances on days with no activity. Note that accounts with zero balances are excluded from daily balance tables. |
| BALANCE_CHANGED_ON_DATE | BOOLEAN | Boolean flag indicating whether the balance actually changed on this specific date. TRUE means there was a balance-changing transaction on this date, FALSE means the balance was forward-filled from a previous date to maintain a complete daily time series. |
| SOL_DAILY_BALANCES_ID | TEXT | A unique, stable identifier for each record in this table. The primary key (PK) ensures that every row is uniquely identifiable and supports efficient joins, lookups, and data integrity across models. The PK may be a natural key (such as a blockchain transaction hash) or a surrogate key generated from one or more fields, depending on the tableās structure and requirements. |
| INSERTED_TIMESTAMP | TIMESTAMP_NTZ | The timestamp when this transaction record was first inserted into the analytics database. Used for data freshness tracking and incremental model logic. Format: YYYY-MM-DD HH:MI:SS. Not derived from the blockchain, but from the ETL process. |
| MODIFIED_TIMESTAMP | TIMESTAMP_NTZ | The timestamp when this transaction record was last updated in the analytics database. Used for tracking updates and supporting incremental model logic. Format: YYYY-MM-DD HH:MI:SS. Not derived from the blockchain, but from the ETL process. |
| _INVOCATION_ID | TEXT |
Column Details
BALANCE_DATE
Example:- 2024-01-15
- 2024-01-16
- Essential for time-series analysis of token balances, portfolio tracking, and historical balance lookups.
- Daily balance trending, portfolio performance analysis, holder distribution over time, and balance change pattern analysis.
ACCOUNT
Example:- Native SOL:
7GgkQ2...(wallet address)
AMOUNT
Example:- SOL:
0.23456789(represents 0.23456789 SOL after a transfer)
LAST_BALANCE_CHANGE
Example:- 2024-01-10 (when balance_date is 2024-01-15, indicating no changes for 5 days)
- Used to identify active vs. inactive accounts, understand balance change frequency, and distinguish between actual balance changes and forward-filled values.
- Only accounts with positive balances are tracked.
- Account activity analysis, dormant account identification, balance change frequency tracking, data freshness assessment, and identifying when accounts last held positive balances.
BALANCE_CHANGED_ON_DATE
Example:- TRUE (balance changed on this date)
- FALSE (balance carried forward from previous day)
- Distinguishes between days with actual balance activity versus days where balances are carried forward. Critical for understanding account activity patterns and data completeness.
- Account activity tracking, identifying active trading days, filtering for actual balance changes, and understanding transaction frequency patterns.