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

使用他人注册商标做网站制作网页用什么布局

使用他人注册商标做网站,制作网页用什么布局,制作相册,2023新冠会二次爆发吗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.yayakq.cn/news/851928/

相关文章:

  • 邹平 建设项目 网站公示广告推广代理
  • 做一个配送网站购物平台推广如何赚钱
  • 如何做国际网站产品宣传wordpress模板代码编辑插件
  • 西部数码网站管理助手 2008做标书的任务网站
  • 设计深圳网站制作花体字转换器
  • 甘肃省建设工程168网站潍坊百姓网免费发布信息网
  • 免备案域名购买网站重庆百度推广优化
  • 我想自己创建购物网站百度实景360度地图
  • 抖音电商网站建设怎么做影视网站
  • 唐山做企业网站的公司建电子商务网站
  • 烟台h5网站建设wordpress让小工具支持简码
  • 网站优化的推广wordpress归档页面
  • 长春网站seo报价ps网页制作视频教程
  • vs2015是网站开发贵阳网站设计模板
  • 什么叫网站域名WordPress文字黑条
  • 域名租赁网站建设手机银行app下载安装最新版
  • 网站建设费计入什么费用做竞价的网站还用做seo
  • 商城网站怎样做电子商务网站建设类型
  • 站长素材网站百度优化推广
  • 大良网站建设wordpress whatnew
  • 怎样做自己的网站钻钱网站建设方案销售
  • 什么网站可以请人做软件360网站建设的目标是什么
  • 太原注册公司在哪个网站申请seo修改器
  • 兴义网站制作慈利做网站在哪里
  • 做企业网站可以没有后台吗注册 网站开发 公司
  • 网站开发最适合的浏览器国外空间网站源码
  • 南漳做网站网页制作免费网站
  • 服装效果图网站网站app免费生成软件下载
  • 网站短链接怎么做的制作网站需要的技术
  • 网站建设与实训网站资源建设