mysql 查询 系统字段 自然日_Mysql查询用户留存/留存率问题用户n日(内)留存、某日新增用户n日(内)留存...
生活随笔
收集整理的這篇文章主要介紹了
mysql 查询 系统字段 自然日_Mysql查询用户留存/留存率问题用户n日(内)留存、某日新增用户n日(内)留存...
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
Mysql查詢用戶留存/留存率語法
- 計算某日的客戶在第n日再次出現(xiàn)的概率--用戶n日留存率。
- 計算某日的客戶在某個時間段內(nèi)再次出現(xiàn)的概率--用戶n日內(nèi)留存率。
- 計算某日新增的用戶在第n日再次出現(xiàn)的概率--新用戶n日留存率。
- 計算某日新增的用戶在某個時間段內(nèi)再次出現(xiàn)的概率--新用戶n日內(nèi)留存率。
1.用戶n日留存/留存率
計算某日的客戶在第n日再次出現(xiàn)的概率--用戶n日留存率。
- 表名:訂單總表;字段:客戶編號,下單時間
--?用戶次日、3日、7日、30日,...留存/留存率
select?*,
?concat(round(100*次日留存用戶/日活躍用戶數(shù),2),'%')??次日留存率,
?concat(round(100*三日留存用戶/日活躍用戶數(shù),2),'%')??三日留存率,
?concat(round(100*七日留存用戶/日活躍用戶數(shù),2),'%')??七日留存率
from?(
?select?
??date(a.下單時間)?as?日期,
??count(distinct?a.客戶編號)?as?日活躍用戶數(shù),
??count(distinct?b.客戶編號)?as?次日留存用戶,
??count(distinct?c.客戶編號)?as?三日留存用戶,
??count(distinct?d.客戶編號)?as?七日留存用戶
?from?訂單總表?a?
??left?join?訂單總表?b?
???on?a.客戶編號?=?b.客戶編號?
???and?date(b.下單時間)?=?date(a.下單時間)?+?1
??left?join?訂單總表?c?
???on?a.客戶編號?=?c.客戶編號?
???and?date(c.下單時間)?=?date(a.下單時間)?+?3
??left?join?訂單總表?d?
???on?a.客戶編號?=?d.客戶編號?
???and?date(d.下單時間)?=?date(a.下單時間)?+?7
?where?date(a.下單時間)?between?"2020/09/01"?and?"2020/09/05"?
?group?by?date(a.下單時間)
)?p;
2.用戶n日內(nèi)留存/留存率
計算某日的客戶在某個時間段內(nèi)再次出現(xiàn)的概率--用戶n日內(nèi)留存率。
--?2.用戶n日內(nèi)留存/留存率--?用戶次日內(nèi)、3日內(nèi)、7日內(nèi)、30日內(nèi),...留存/留存率
select?*,
?concat(round(100*次日內(nèi)留存用戶/日活躍用戶數(shù),2),'%')??次日內(nèi)留存率,
?concat(round(100*三日內(nèi)留存用戶/日活躍用戶數(shù),2),'%')??三日內(nèi)留存率,
?concat(round(100*七日內(nèi)留存用戶/日活躍用戶數(shù),2),'%')??七日內(nèi)留存率
from?(
?select?
??date(a.下單時間)?as?日期,
??count(distinct?a.客戶編號)?as?日活躍用戶數(shù),
??count(distinct?b.客戶編號)?as?次日內(nèi)留存用戶,
??count(distinct?c.客戶編號)?as?三日內(nèi)留存用戶,
??count(distinct?d.客戶編號)?as?七日內(nèi)留存用戶
?from?訂單總表?a?
??left?join?訂單總表?b?
???on?a.客戶編號?=?b.客戶編號?
???and?date(b.下單時間)?=?date(a.下單時間)?+?1
??left?join?訂單總表?c?
???on?a.客戶編號?=?c.客戶編號?
???and?(date(c.下單時間)?BETWEEN?date(a.下單時間)?+?1?AND?date(a.下單時間)?+?3)
??left?join?訂單總表?d?
???on?a.客戶編號?=?d.客戶編號?
???and?(date(d.下單時間)?BETWEEN?date(a.下單時間)?+?1?AND?date(a.下單時間)?+?7)
?where?date(a.下單時間)?between?"2020/09/01"?and?"2020/09/05"?
?group?by?date(a.下單時間)
)?p;
3.新增用戶n日留存/留存率
計算某日新增的用戶在第n日再次出現(xiàn)的概率--新用戶n日留存率。
##?3.某日新增用戶留存/留存率##?計算某日新增的用戶在次日、3日、7日的留存率--新用戶n日留存
select?*,
?concat(round(100*次日留存用戶/日新增用戶數(shù),2),'%')??次日留存率,
?concat(round(100*三日留存用戶/日新增用戶數(shù),2),'%')??三日留存率,
?concat(round(100*七日留存用戶/日新增用戶數(shù),2),'%')??七日留存率
from?(
?select?
??date(a.下單時間)?as?新增日期,
??count(distinct?a.客戶編號)?as?日新增用戶數(shù),
??count(distinct?b.客戶編號)?as?次日留存用戶,
??count(distinct?c.客戶編號)?as?三日留存用戶,
??count(distinct?d.客戶編號)?as?七日留存用戶
?from?
?(
??select??
???date(t1.下單時間)?as?下單時間,
???t1.客戶編號?
??from?訂單總表?as?t1
???left?join?訂單總表?as?t2
???on?t1.客戶編號=t2.客戶編號
???and?t2.下單時間??where?
???(date(t1.下單時間)?between?"2020/09/01"?and?"2020/09/05")?
??and?t2.下單時間?is?Null??
?)?as?a?
??left?join?訂單總表?b?
???on?a.客戶編號?=?b.客戶編號?
???and?date(b.下單時間)?=?date(a.下單時間)?+?1
??left?join?訂單總表?c?
???on?a.客戶編號?=?c.客戶編號?
???and?date(c.下單時間)?=?date(a.下單時間)?+?3
??left?join?訂單總表?d?
???on?a.客戶編號?=?d.客戶編號?
???and?date(d.下單時間)?=?date(a.下單時間)?+?7
?group?by?date(a.下單時間)
)?p;
4.新增用戶n日內(nèi)留存率
計算某日新增的用戶在次日內(nèi)、3日內(nèi)、7日內(nèi)的留存率--新用戶n日內(nèi)留存率。
##?4.新增用戶n日內(nèi)留存率##?計算某日新增的用戶在次日內(nèi)、3日內(nèi)、7日內(nèi)的留存率--新用戶n日內(nèi)留存率。
select?*,
?concat(round(100*次日留存用戶/日新增用戶數(shù),2),'%')??次日留存率,
?concat(round(100*三日留存用戶/日新增用戶數(shù),2),'%')??三日留存率,
?concat(round(100*七日留存用戶/日新增用戶數(shù),2),'%')??七日留存率
from?(
?select?
??date(a.下單時間)?as?新增日期,
??count(distinct?a.客戶編號)?as?日新增用戶數(shù),
??count(distinct?b.客戶編號)?as?次日留存用戶,
??count(distinct?c.客戶編號)?as?三日留存用戶,
??count(distinct?d.客戶編號)?as?七日留存用戶
?from?
?(
??select??
???date(t1.下單時間)?as?下單時間,
???t1.客戶編號?
??from?訂單總表?as?t1
???left?join?訂單總表?as?t2
???on?t1.客戶編號=t2.客戶編號
???and?t2.下單時間??where?
???(date(t1.下單時間)?between?"2020/09/01"?and?"2020/09/05")?
??and?t2.下單時間?is?Null??
?)?as?a?
??left?join?訂單總表?b?
???on?a.客戶編號?=?b.客戶編號?
???and?date(b.下單時間)?=?date(a.下單時間)?+?1
??left?join?訂單總表?c?
???on?a.客戶編號?=?c.客戶編號?
???and?(date(c.下單時間)?BETWEEN?date(a.下單時間)?+?1?AND?date(a.下單時間)?+?3)
??left?join?訂單總表?d?
???on?a.客戶編號?=?d.客戶編號?
???and?(date(d.下單時間)?BETWEEN?date(a.下單時間)?+?1?AND?date(a.下單時間)?+?7)
?group?by?date(a.下單時間)
)?p;
掃碼關注更多數(shù)據(jù)分析與運營知識干貨在此,隨時學習!、
總結(jié)
以上是生活随笔為你收集整理的mysql 查询 系统字段 自然日_Mysql查询用户留存/留存率问题用户n日(内)留存、某日新增用户n日(内)留存...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微信群昵称247个
- 下一篇: python mysql操作_Pytho