sql 按照天环比_SQL知识:自查询

YQ是也:sql高阶教程:非等值自连接​zhuanlan.zhihu.com

1.用SQL生成有序对非常简单。像下面这样通过交叉连接生成笛卡尔积,就可以得到有序对。

SELECT P1.name AS name_1, P2.name AS name_2
FROM Products P1, Products P2;

2.为了去掉(苹果,苹果)这种由相同元素构成的对,需要像下面这样加上一个条件,然后再进行连接运算。

SELECT P1.name AS name_1, P2.name AS name_2
FROM Products P1, Products P2
WHERE P1.name <> P2.name;

#在以后多用’<>‘,戒掉’=!‘

3.进一步对(苹果,橘子)和(橘子,苹果)这样只是调换了元素顺序的对进行去重。

SELECT P1.name AS name_1, P2.name AS name_2 
FROM Products P1, Products P2 
WHERE P1.name > P2.name;

#’>‘此处利用首字母

  • 补充
sql自查询 - 搜索结果 - 知乎​www.zhihu.com
  • Leetcode习题:180题:连续出现的数字

查找表中至少连续出现三次的数字

96c2f05f13b67a084b532d847bf39810.png
Log

select distinct l1.Num as ConsecutiveNums

from Logs l1,Logs l2, Logs l3

where

l1.Id = l2.Id-1 #合并规则,按照id+1来合并

and l2.Id = l3.Id-1

and l1.Num = l2.Num #筛选规则

and l2.Num = l3.Num

  • 公众号:数据管道

每天的活跃用户数和活跃30天留存用户数

c051f051b7ec4f08ea70956a243bec69.png

select

A.date,A.日活跃用户数,B.活跃30天留存用户数

from (

select date,count(*) 日活跃用户数

from active

group by date) A

left join (

select a1.date,count(a1.user_id) 活跃30天留存用户数

from active a1,active a2

where a1.user_id=a2.user_id and Date(a1.date)+29<a2.date

group by a1.date) B

on A.date=B.date;

还是有问题,输出的是null不是0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值