现有三表
表1 用户阅读资讯表 表2 用户添加股票票 表3 用户注册账户表
问题 求阅读完资讯后添加股票的这一部分用户的注册率是多少?
求问 我这样写算的逻辑出来结果为什么为1 正确的写法应该是什么 谢谢
select count(distinct case when p.user_id is not null then p.user_id end)/count(distinct t.user_id)
from
(
select t2.user_id,t2.add_date
from
(select user_id,add_date
from 资讯表
) as t1
inner join
(
select user_id,add_date
from 选股表
) as t2
on t1.user_id=t2.user_id
where t1.add_date<=t2.add_date
) as t
left join(
select user_id, add_date
from 注册表
)as p
on p.user_id=t.user_id
where p.add_date >=t.add_date
hive sql连接问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- 啊啊清欢 2022-05-11 09:20关注
SELECT count(DISTINCT CASE WHEN p.user_id IS NOT NULL and p.add_date >=t.add_date THEN p.user_id END)/count(DISTINCT t.user_id)
FROM (SELECT t2.user_id,
t2.add_date
FROM (SELECT user_id, add_date FROM 资讯表 ) AS t1
INNER JOIN (SELECT user_id, add_date FROM 选股表 ) AS t2 ON t1.user_id=t2.user_id
WHERE t1.add_date<=t2.add_date
) AS t
LEFT JOIN ( SELECT user_id, add_date FROM 注册表 )AS p ON p.user_id=t.user_id;本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥40 复杂的限制性的商函数处理
- ¥15 程序不包含适用于入口点的静态Main方法
- ¥15 素材场景中光线烘焙后灯光失效
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码