我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MYSQL LAG()与LEAD()的区别

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MYSQL LAG()与LEAD()的区别

这两个函数是偏移量函数,可以查出一个字段的前面N个值或者后面N个值,配合over来使用。

下面举例说明,新建表格如下:

drop table if exists exam_record;
CREATE TABLE exam_record (
    id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
    uid int NOT NULL COMMENT '用户ID',
    exam_id int NOT NULL COMMENT '试卷ID',
    start_time datetime NOT NULL COMMENT '开始时间',
    submit_time datetime COMMENT '提交时间',
    score tinyint COMMENT '得分'
)CHARACTER SET utf8 COLLATE utf8_general_ci;
INSERT INTO exam_record(uid,exam_id,start_time,submit_time,score) VALUES
(1001, 9001, '2020-01-01 09:01:01', '2020-01-01 09:21:59', 90),
(1002, 9001, '2020-01-20 10:01:01', '2020-01-20 10:10:01', 89),
(1002, 9001, '2020-02-01 12:11:01', '2020-02-01 12:31:01', 83),
(1003, 9001, '2020-03-01 19:01:01', '2020-03-01 19:30:01', 75),
(1004, 9001, '2020-03-01 12:01:01', '2020-03-01 12:11:01', 60),
(1003, 9001, '2020-03-01 12:01:01', '2020-03-01 12:41:01', 90),
(1002, 9001, '2020-05-02 19:01:01', '2020-05-02 19:32:00', 90),
(1001, 9002, '2020-01-02 19:01:01', '2020-01-02 19:59:01', 69),
(1004, 9002, '2020-02-02 12:01:01', '2020-02-02 12:20:01', 99),
(1003, 9002, '2020-02-02 12:01:01', '2020-02-02 12:31:01', 68),
(1001, 9002, '2020-02-02 12:01:01', '2020-02-02 12:43:01', 81),
(1001, 9002, '2020-03-02 12:11:01', null, null);

MYSQL LAG()与LEAD()的区别

 1.lag()

语法:lag(expr,N,default)

  • expr:它可以是列或任何内置函数。
  • N:它是一个正值,它确定当前行之前的行数。如果在查询中将其省略,则其默认值为1
  • default:如果在当前行之前没有行N行的情况下,它是函数返回的默认值。如果缺少,则默认为NULL。
select *,lag(start_time,1) over(order by id)lad_1,
lag(uid,2) over(order by id)lad_2 
from exam_record

MYSQL LAG()与LEAD()的区别

可以看到所有的start_time都等于前面一个的start_time,前面没有的填充NULL,设置lag()里面的参数为2,可以看到所有的uid偏移了两个。

select *,lag(start_time,2,0) over(partition by uid order by id)lag_1
from exam_record

MYSQL LAG()与LEAD()的区别

根据uid分组对start_time向前移动2个单元,然后设置NULL值默认填充为0. 可以自己体会一下数据的移动方式。

2.lead()

语法:lead(expr,N,default)

  • expr:它可以是列或任何内置函数。
  • N:它是一个正值,它确定当前行之后的行数。如果在查询中将其省略,则其默认值为1
  • default:如果在当前行之后没有行N行的情况下,它是函数返回的默认值。如果缺少,则默认为NULL。
select *,lead(start_time,1) over(order by id)lead_1,
lead(uid,2) over(order by id)lead_2 
from exam_record

MYSQL LAG()与LEAD()的区别

可以看到所有的start_time都等于后面一个的start_time,后面没有的填充NULL,设置lead()里面的参数为2,可以看到所有的uid都等于后面第二个的uid。

select *,lead(start_time,1) over(partition by uid order by id)lead_1
from exam_record

MYSQL LAG()与LEAD()的区别

 还可以根据uid进行分组,然后再进行偏移。

到此这篇关于mysql LAG()与LEAD()的区别的文章就介绍到这了,更多相关MYSQL LAG() LEAD()内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MYSQL LAG()与LEAD()的区别

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MYSQL LAG()与LEAD()的区别

目录 1.lag()2.lead()这两个函数是偏移量函数,可以查出一个字段的前面N个值或者后面N个值,配合over来使用。下面举例说明,新建表格如下:drop table if exists exam_record;CREATE T
2023-05-16

【Mysql系列】LAG与LEAD开窗函数

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,
【Mysql系列】LAG与LEAD开窗函数
2023-12-22

MySQL中LAG()函数和LEAD()函数的使用

目录一、窗口函数的基本用法二、LAG()和LEAD()函数介绍三、数据准备(建表sql在最后)四、建表数据sql一、窗口函数的基本用法从mysql8之后才开始支持窗口函数 OVER ([PARTITION BY <用于分组的
2022-08-12

MySQL MyISAM 与InnoDB 的区别

区别:1. InnoDB支持事务,MyISAM不支持,对于InnoDB每一条SQL语言都默认封装成事务,自动提交,这样会影响速度,所以最好把多条SQL语言放在begin和commit之间,组成一个事务; 2. InnoDB支持外键,而MyI
2022-05-30

Oracle与MySQL的区别详解

目录什么是mysql?什么是oracle?MySQL的优点MySQphpL的缺点Oracle的优点Oracle的缺点Oracle与MySQL的区别?什么是MySQLandroid?MySQL是一个关系型数据库管理系统,由瑞典MySQL A
2023-04-14

mysql中null与(null)的区别

在 mysql 中,null 代表空值,不占用空间,而 (null) 是空字符串值,占用 1 字节空间。它们的区别包括:存储方式不同、比较方式不同、插入方式不同、聚合函数处理方式不同、索引使用不同。MySQL 中 NULL 与 (NULL)
mysql中null与(null)的区别
2024-05-01

mysql中null与(null的区别

mysql 中 null 和 (null) 区别如下:null 表示未知值,而 (null) 表示明确空值。null 不占用存储空间,而 (null) 占用一个字节。null 不等于任何值,而 (null) 等于它自己。null 用于表示缺
mysql中null与(null的区别
2024-05-01

mysql中replaceinto与insertinto区别

本文主要介绍了mysql中replaceinto与insertinto区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-18

Oracle与MySQL的区别是什么

这篇文章主要讲解了“Oracle与MySQL的区别是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Oracle与MySQL的区别是什么”吧!什么是MySQL?MySQL是一个关系型数据库
2023-07-06

编程热搜

目录