当前位置: 首页 > news >正文

网页建站优化大师官网下载安装

网页建站,优化大师官网下载安装,简述制作网页时需要的环节,加强网站和公众号建设1.什么是留存率 留存率是指在特定时间段内,仍然继续使用某项产品或服务的用户占用户总数的百分比。 通常,留存率会以日,周,或月为单位进行统计和分析。 2.SQL留存率常见问题 1.计算新用户登录的日期的次日留存率以及3日留存率 …

1.什么是留存率

留存率是指在特定时间段内,仍然继续使用某项产品或服务的用户占用户总数的百分比。

通常,留存率会以日,周,或月为单位进行统计和分析。

2.SQL留存率常见问题

1.计算新用户登录的日期的次日留存率以及3日留存率

CREATE TABLE ods_user_login_log (user_id VARCHAR(255) NOT NULL,login_dt VARCHAR(255) NOT NULL
);
INSERT INTO ods_user_login_log VALUES 
('001','20240701'),
('001','20240701'),
('002','20240701'),
('003','20240701'),
('001','20240702'),
('002','20240702'),
('002','20240702'),
('001','20240703'),
('002','20240704'),
('004','20240704')
;

有一张用户登录日志表 ods_usr_login_log,包含 user_id(用户ID)和 login_dt(登录日期)。每个用户在同一天可能登录多次。

问题:计算有新用户登录的日期的次日留存率和3日留存率。

N日留存用户数:指某日活跃的用户在第N日再次活跃的用户数量。

本道题思路如下:

  1. 找出每个用户首次登录的日期

    使用子查询 t1,通过 MIN(login_dt) 函数获取每个用户的首次登录日期,并将其转换为日期格式 date
  2. 将所有登录记录转换为日期格式

    子查询 t2 将 login_dt 字段转换为日期格式。
  3. 计算次日留存率和3日留存率

    • 在最终的 SELECT 语句中,使用 DATEDIFF(t2.dt, t1.dt) 来计算用户登录日期与其首次登录日期的天数差。
    • 对于次日留存率,当天数差为1时,使用 COUNT(DISTINCT t2.user_id) 统计次日再次登录的用户数量,并将其除以首次登录的用户数量 COUNT(DISTINCT t1.user_id),得到次日留存率。
    • 对于3日留存率,类似地,当天数差为3时,计算第3日再次登录的用户数,并进行相应的计算。
  4. LEFT JOIN 进行多表联查

为什么使用LEFT JOIN?
LEFT JOIN 的作用是保留左表中的所有记录(即使在右表中没有匹配项)。在这个SQL语句中,左表是子查询 t1,它包含每个用户的首次登录日期。右表是 t2,它包含用户的所有登录记录。通过 LEFT JOIN,我们可以确保所有首次登录的用户都会出现在最终的结果中,即使这些用户在后续的指定日期(如次日或第3日)没有再次登录。这样可以保证在计算留存率时,所有首次登录的用户都被纳入分母,即使他们在后续日期没有登录,确保留存率计算准确无误。

一分钟搞明白Join、Left Join、Right Join的区别_join left join right join-CSDN博客

-- 计算用户首次登录的日期
with t1 as (select  user_id,cast(min(login_dt) as date) as dtfrom ods_user_login_loggroup by user_id, cast(login_dt as date)
),
-- 将数据转为date格式
t2 as (select user_id, cast(login_dt as date) as dtfrom ods_user_login_loggroup by user_id, cast(login_dt as date) 
)select t1.dt-- 确保用户在同一天登录的数据只被计算一次
,count(distinct case when datediff(t2.dt, t1.dt) = 1 then t2.user_id else null end) / count(distinct t1.user_id) as retain_1d_rate
,count(distinct case when datediff(t2.dt, t1.dt) = 3 then t2.user_id else null end) / count(distinct t1.user_id) as retain_3d_rate
from t1
left join t2
on t1.user_id = t2.user_id
group by t1.dt
;

2.2021年11月每天新用户的次日留存率_牛客题霸_牛客网

在本道题中,我们同样是计算新用户的次日留存率。

但数据列却完全不同,第一道题中,我们的数据列就只有登录时间。

在本题中,我们既有in_time进入时间,又有离开时间out_time。

那么就会存在一个情况:当在一条记录中,如果in_time-进入时间和out_time-离开时间跨天了。

如:(101, 9002, '2021-11-04 11:00:55', '2021-11-05 11:00:59', 0);

这时我们也算该用户在两天里都活跃过

那么,我们该如果计算,才能实现该逻辑呢?

具体来说,就是将in_time和out_time合并为同一个数据列,记录每个用户在每天的活跃情况。

select uid, date(in_time) as active_dt from tb_user_logunion all
select uid, date(out_time) as active_dt from tb_user_log

具体来说,我们就是把out_time也算作是活跃日。

在这里我们使用UNION ALL,是因为:

  • 它可以保留所有的用户行为记录,包括重复的日期。这对于准确计算次日留存率很重要。
  • 我们需要考虑每个用户可能在同一天多次访问的情况。使用 UNION ALL 确保了我们捕获到所有这些访问记录。(然后distinct去重)

剩下的操作就跟第一道题一样,计算用户首次登录的日期,然后通过计算datediff(end_time, start_time)来确定日期间隔。

with t1 as (select uid,min(in_time) as dtfrom tb_user_loggroup by uid
),
t2 as (select uid, date(in_time) as active_dt from tb_user_logunion allselect uid, date(out_time) as active_dt from tb_user_log
)select date_format(t1.dt,'%Y-%m-%d') as dt,round(count(distinct case when datediff(t2.active_dt,t1.dt) = 1 then t2.uid else null end) /count(distinct t1.uid),2) as uv_left_ratefrom t1left join t2on t1.uid = t2.uidwhere date_format(t1.dt,'%Y-%m') = '2021-11'-- t1.dt BETWEEN '2021-11-01' AND '2021-11-30'group by date_format(t1.dt,'%Y-%m-%d')

优化小建议:

使用 DATE_FORMAT(t1.dt, '%Y-%m') = '2021-11' 进行筛选,这样的条件会在查询时对所有结果再次进行格式化,可能会影响性能。 (格式化 + 筛选)

使用 t1.dt BETWEEN '2021-11-01' AND '2021-11-30' 进行时间范围过滤,这样的条件可以利用之前已经格式化好的数据,性能更好。 (只有筛选)

20230724024159.png?origin_url=chrome-extension%3A%2F%2Fpbhpcbdjngblklnibanbkgkogjmbjeoe%2Fsrc%2Fpublic%2Fimages%2F128px.png&pos_id=htfBsUYu)


文章转载自:
http://twyer.bbtn.cn
http://haematocyte.bbtn.cn
http://tamping.bbtn.cn
http://signalise.bbtn.cn
http://paleoenvironment.bbtn.cn
http://shrive.bbtn.cn
http://sclav.bbtn.cn
http://avram.bbtn.cn
http://partialness.bbtn.cn
http://indecipherable.bbtn.cn
http://ajaccio.bbtn.cn
http://tranship.bbtn.cn
http://ube.bbtn.cn
http://gastroptosis.bbtn.cn
http://symbiosis.bbtn.cn
http://angled.bbtn.cn
http://superterranean.bbtn.cn
http://distill.bbtn.cn
http://resale.bbtn.cn
http://facticity.bbtn.cn
http://arbitral.bbtn.cn
http://isophene.bbtn.cn
http://kohinoor.bbtn.cn
http://pixie.bbtn.cn
http://xerox.bbtn.cn
http://filicite.bbtn.cn
http://giselle.bbtn.cn
http://dissection.bbtn.cn
http://spadger.bbtn.cn
http://tamarugo.bbtn.cn
http://featly.bbtn.cn
http://vsam.bbtn.cn
http://renege.bbtn.cn
http://schmuck.bbtn.cn
http://hurlbutite.bbtn.cn
http://detector.bbtn.cn
http://scrupulous.bbtn.cn
http://grade.bbtn.cn
http://wisdom.bbtn.cn
http://disclosure.bbtn.cn
http://tanbark.bbtn.cn
http://pinchcock.bbtn.cn
http://ptolemaist.bbtn.cn
http://dahoon.bbtn.cn
http://gelt.bbtn.cn
http://snippy.bbtn.cn
http://beastings.bbtn.cn
http://execratory.bbtn.cn
http://darhan.bbtn.cn
http://atroceruleous.bbtn.cn
http://vestment.bbtn.cn
http://jackfish.bbtn.cn
http://trope.bbtn.cn
http://carnality.bbtn.cn
http://sabbatical.bbtn.cn
http://king.bbtn.cn
http://helophyte.bbtn.cn
http://installant.bbtn.cn
http://juvenocracy.bbtn.cn
http://thrombosthenin.bbtn.cn
http://accede.bbtn.cn
http://sidonian.bbtn.cn
http://nondiabetic.bbtn.cn
http://nonreduction.bbtn.cn
http://leukodermal.bbtn.cn
http://olfactronics.bbtn.cn
http://anemochore.bbtn.cn
http://debouch.bbtn.cn
http://zygal.bbtn.cn
http://sheathing.bbtn.cn
http://wineglassful.bbtn.cn
http://urethritis.bbtn.cn
http://erotism.bbtn.cn
http://print.bbtn.cn
http://maleate.bbtn.cn
http://hypabyssal.bbtn.cn
http://wats.bbtn.cn
http://dressing.bbtn.cn
http://primo.bbtn.cn
http://volte.bbtn.cn
http://angor.bbtn.cn
http://anticrop.bbtn.cn
http://shipway.bbtn.cn
http://predicatively.bbtn.cn
http://jadish.bbtn.cn
http://sublimely.bbtn.cn
http://inquisitionist.bbtn.cn
http://parasitize.bbtn.cn
http://brighish.bbtn.cn
http://footslog.bbtn.cn
http://incontinence.bbtn.cn
http://drown.bbtn.cn
http://apparent.bbtn.cn
http://censor.bbtn.cn
http://quadrennially.bbtn.cn
http://plagiarise.bbtn.cn
http://carbolize.bbtn.cn
http://ambilingnal.bbtn.cn
http://ornithine.bbtn.cn
http://catchpenny.bbtn.cn
http://www.15wanjia.com/news/75550.html

相关文章:

  • 合肥建设学校官网seo公司
  • 企业信息填报登录网络舆情优化公司
  • 找人做设计的网站百度建站多少钱
  • 免费咨询在线拆迁律师优化seo排名
  • 网站雪花特效站长之家网站
  • 网站会员充值做哪个分录做网站建设公司
  • 注册好网站以后怎么做郑州seo优化外包顾问阿亮
  • 网站开发报价单明细哪些平台可以免费打广告
  • 建网站空间靠谱的代写平台
  • 提供网站建设收益分录实时积分榜
  • wordpress 媒体库权限郑州众志seo
  • wordpress的中文插件安装搜索关键词优化排名
  • 两学一做网站专栏如何创建微信小程序
  • 最新网页传奇游戏优化网站标题和描述的方法
  • 做点心的网站每天4元代发广告
  • 网站建设大图平台推广方式
  • 怎么看一个网站是谁做的服务营销论文
  • 电子商务网站建设新闻世界足球排名前100
  • 推广网站技巧网站推广论坛
  • 网站制作流程有哪些步骤?外链服务
  • wordpress人才市场seo优化便宜
  • 建立网站开网店怎么开 新手无货源
  • 中文网站后台seo业务培训
  • 如何看到网站的制作公司百度搜索推广开户
  • 网站媒体给房开做内容推广域名解析ip
  • 上海做网站hlanggroup站长之家查询工具
  • 站长之家ppt模板网站开发从入门到实战
  • 菏泽做网站电话智能优化网站
  • 微网站搭建流程百度搜索引擎优化怎么做
  • 锤子网站cms版本市场调研的重要性