Skip to content

Instantly share code, notes, and snippets.

@medvedev1088
Created December 4, 2018 09:25
Show Gist options
  • Save medvedev1088/3ab0e863912d39ff3e8da26496944690 to your computer and use it in GitHub Desktop.
Save medvedev1088/3ab0e863912d39ff3e8da26496944690 to your computer and use it in GitHub Desktop.
#standardSQL
-- MIT License
-- Copyright (c) 2018 Evgeny Medvedev, [email protected]
with double_entry_book as (
-- debits
select to_address as address, value as value, block_timestamp, block_number
from `bigquery-public-data.ethereum_blockchain.traces`
where to_address is not null
and status = 1
and (call_type not in ('delegatecall', 'callcode', 'staticcall') or call_type is null)
union all
-- credits
select from_address as address, -value as value, block_timestamp, block_number
from `bigquery-public-data.ethereum_blockchain.traces`
where from_address is not null
and status = 1
and (call_type not in ('delegatecall', 'callcode', 'staticcall') or call_type is null)
union all
-- transaction fees debits
select miner as address, sum(cast(receipt_gas_used as numeric) * cast(gas_price as numeric)) as value, block_timestamp, block_number
from `bigquery-public-data.ethereum_blockchain.transactions` as transactions
join `bigquery-public-data.ethereum_blockchain.blocks` as blocks on blocks.number = transactions.block_number
group by blocks.miner, block_timestamp, block_number
union all
-- transaction fees credits
select from_address as address, -(cast(receipt_gas_used as numeric) * cast(gas_price as numeric)) as value, block_timestamp, block_number
from `bigquery-public-data.ethereum_blockchain.transactions`
)
select address, sum(value) as balance
from double_entry_book
where block_number <= 6000000
group by address
order by balance desc
limit 10
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment