saeide-ahmadi-7Flow Users Retention
Updated 2022-07-20
99
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
›
⌄
WITH last_tx AS (
SELECT
proposer as user_address,
max(date(block_timestamp)) AS last_tx_date
FROM
flow.core.fact_transactions
WHERE
TX_SUCCEEDED = true
GROUP BY
proposer
),
prev_last_tx AS (
SELECT
proposer as user_address,
max(date(block_timestamp)) AS prev_last_tx_date
FROM
flow.core.fact_transactions join last_tx
on proposer = user_address
WHERE
date(block_timestamp) < last_tx_date and
TX_SUCCEEDED = true
GROUP BY
proposer
),
user_retention AS (
SELECT
last_tx.user_address as user_address,
datediff('day', prev_last_tx_date, last_tx_date) AS retention_duration
FROM
last_tx join prev_last_tx
ON last_tx.user_address = prev_last_tx.user_address
)
SELECT
retention_duration,
COUNT(DISTINCT user_address) as "number of user addresses"
Run a query to Download Data