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

京网站建设怎么买域名自己做网站

京网站建设,怎么买域名自己做网站,北京专业做网站电话,wordpress获取子菜单180. 连续出现的数字 表:Logs -------------------- | Column Name | Type | -------------------- | id | int | | num | varchar | -------------------- 在 SQL 中,id 是该表的主键。 id 是一个自增列。 找出所有至少连续出现三次的数字。 返回的…

180. 连续出现的数字

表:Logs

±------------±--------+
| Column Name | Type |
±------------±--------+
| id | int |
| num | varchar |
±------------±--------+
在 SQL 中,id 是该表的主键。
id 是一个自增列。

找出所有至少连续出现三次的数字。

返回的结果表中的数据可以按 任意顺序 排列。

结果格式如下面的例子所示:

示例 1:

输入:
Logs 表:
±—±----+
| id | num |
±—±----+
| 1 | 1 |
| 2 | 1 |
| 3 | 1 |
| 4 | 2 |
| 5 | 1 |
| 6 | 2 |
| 7 | 2 |
±—±----+
输出:
Result 表:
±----------------+
| ConsecutiveNums |
±----------------+
| 1 |
±----------------+
解释:1 是唯一连续出现至少三次的数字。

题解

  • 连续问题
    应该想到lag、lead偏移函数,把数据进行规整打横
  • 至少连续出现三次的数字
    是不是把表通过顺序打横,错位就行?

思考:针对这类问题,你就细想,怎么实现呢?
sql又不是代码,没办法计数,还要连续,怎么办呢?起码应该想到的就是组合?
怎么组合? union、join、有没有现成的函数?也没别的方式了呀,心里kemo【模拟】一下,很显然union是不行的,只能join,咋join呢?

于是乎就想到了这2种方法:

方法一 表自关联

不是要至少连续三次吗?把连续三次的搞出来呗

表自关联三次,因为数据是有序的,那是不是把第二张表向上平移下,第三张表再向上平移下就可以了呢? 边看结果边思考,样图如下

selectl1.num as ConsecutiveNums
from logs l1 join logs l2 join logs l3
on l1.id=l2.id-1 and l2.id=l3.id-1
where l1.num=l2.num and l2.num=l3.num

在这里插入图片描述

方法二 lag、lead偏移函数

先找找定义,官网或者百度一下就清楚了,看到函数说明以后心里的石头终于落地了,太简单了吧?
lead一下抵扣咱们join三次呀,搞起搞起!!!

Lag函数:将数据向下偏移
Lag函数可以将数据向下偏移指定的行数,使得上方的数据出现空值。例如,你可以使用Lag函数来计算用户的复购间隔,或者在其他需要上下文计算的场景中使用。

语法:
Lag(expression, offset, default_value) over ()
– expression:要取的列名
– offset:取偏移后的第几行数据
– default_value:没有符合条件的默认值

🔄 Lead函数:将数据向上偏移
与Lag函数相反,Lead函数将数据向上偏移指定的行数,使得下方的数据出现空值。这种功能在处理时间序列数据或者需要前瞻性计算时非常有用。

语法:
Lead(expression, offset, default_value) over ()
– expression:要取的列名
– offset:取偏移后的第几行数据
– default_value:没有符合条件的默认值

select tmp.num as ConsecutiveNums from (select id,num,lead(num,1,null) over() as col_2,lead(num,2,null) over() as col_3from logs
) tmp where tmp.num = tmp.col_2 and tmp.num = tmp.col_3

在这里插入图片描述
在这里插入图片描述

ddl

create database test2024;
use test2024;
create table logs (id int primary key , num int);
insert into logs values(1,1),(2,1),(3,1),(4,2),(5,1),(6,2),(7,2);

万变不离其宗,高级函数只是为了让我们使用起来更方便,其实没啥了不起的,别怕,战略藐视。。。。

http://www.rdtb.cn/news/17144.html

相关文章:

  • 你有网站 我做房东 只收佣金的网企业seo推广外包
  • 白云区手机版网站建设全网营销平台
  • 局域网建设网站视频教程免费发广告的网站大全
  • wordpress怎么使用七牛云北京谷歌seo
  • 免费站长统计工具网络广告营销策划方案
  • 网站推荐你懂我的意思吧2020知乎成人营销管理培训班
  • 成都网站建设四川冠辰互联网广告营销
  • 招标网站的服务费怎么做分录哈尔滨百度推广公司
  • wordpress带整站数据100个免费推广b站
  • 如何查看一个网站是什么程序做的手机系统优化软件
  • iis 启用网站 浏览提示service全球搜索引擎市场份额
  • 三明做网站seo排名第一
  • 全运会网站建设方案mac日本官网入口
  • 网站建好以后每年都续费么百度区域代理
  • h5响应式音乐网站模板seo关键词seo排名公司
  • 做淘宝详情的网站百度ai人工智能平台
  • 佛山制作网站软件seo优化的主要内容
  • ps制作网站首页单页应用seo如何解决
  • 网站如何做外链推广手段和渠道有哪些
  • 杭州 网站建设刚刚北京传来重大消息
  • 做网站ie10缓存软文网站推广法
  • zhihe网站建设 淘宝北京最新疫情情况
  • 与狗狗做网站优化大师安卓版
  • 兰州市做网站的公司有哪些汽车行业网站建设
  • 衢州专业做网站谷歌手机版浏览器官网
  • 广州做护肤品的网站浏览器谷歌手机版下载
  • 网站页面打开速度慢网络软文推广网站
  • 网站域名到期不续费会怎么样武汉网站搜索引擎优化
  • 怎么用链接进自己做的网站近期新闻大事
  • 做公司网站棋牌网站排名提升软件