【051】row_number() over() 查询各个用户最长的连续登陆天数?

2024-05-26 23:58

本文主要是介绍【051】row_number() over() 查询各个用户最长的连续登陆天数?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


♣题目部分       查询各个用户最长的连续登陆天数?♣答案部分
row_number() over() 解说例一:      row_number() over() :简单的说row_number()从1开始,为每一条分组记录返回一个数字。例如首先在在线数据库中创建表,插入上图左边源表数据CREATE TABLE IF NOT EXISTS `loadrecord` (  `uid` int(6) unsigned NOT NULL,  `loadtime` varchar(200) NOT NULL,  PRIMARY KEY (`uid`,`loadtime`)) DEFAULT CHARSET=utf8;INSERT INTO `loadrecord` (`uid`, `loadtime`) VALUES  ('201', '2017/1/1'),  ('201', '2017/1/2'),  ('202', '2017/1/2'),  ('202', '2017/1/3'),  ('203', '2017/1/3'),  ('201', '2017/1/4'),  ('202', '2017/1/4'),  ('201', '2017/1/5'),  ('202', '2017/1/5'),  ('201', '2017/1/6'),  ('203', '2017/1/6'),  ('203', '2017/1/7');    其中,select uid,(row_number() over(partition by uid order by uid ) ) AS row_number_uid from loadrecord;返回为升序以后的每条uid记录返回一个序号:row_number() over()分组排序功能:在使用 row_number() over()函数时候,over()里头的分组以及排序的执行晚于 where 、group by、  order by 的执行。
例二:
create table TEST_ROW_NUMBER_OVER(       id varchar(10) not null,       name varchar(10) null,       age varchar(10) null,       salary int null);select * from TEST_ROW_NUMBER_OVER t; insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(1,'a',10,8000);insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(1,'a2',11,6500);insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(2,'b',12,13000);insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(2,'b2',13,4500);insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(3,'c',14,3000);insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(3,'c2',15,20000);insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(4,'d',16,30000);insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(5,'d2',17,1800);
对查询结果进行排序(无分组):
select id,name,age,salary,row_number()over(order by salary desc) rnfrom TEST_ROW_NUMBER_OVER t
根据id分组排序:
select id,name,age,salary,row_number()over(partition by id order by salary desc) `rank`from TEST_ROW_NUMBER_OVER t;
找出每一组中序号为一的数据?
select * from (select id,name,age,salary,row_number()over(partition by id order by salary desc) `rank`from TEST_ROW_NUMBER_OVER ) t where `rank` <2;
排序找出年龄在13岁到16岁数据,按salary排序:
select id,name,age,salary,row_number()over(order by salary desc)  `rank`from TEST_ROW_NUMBER_OVER t where age between '13' and '16';
#结果中 rank 的序号,其实就表明了 over(order by salary desc) 是在where age between and 后执行的
题目答案解析:
#第一步#判断连续的核心是row_number,因为row_number是连续的#所以day-row_number,如果值是恒定的,说明也是连续的,反之一定会变化#简单的说row_number()从1开始,为每一条分组记录返回一个数字,#这里的row_number() over(partition by uid uid 是先把uid列升序,#再为升序以后的每条uid记录返回一个序号。select uid,(day(loadtime) - row_number() over(partition by uid order by uid ) ) AS cnt from loadrecord;
#第二步#第一步得到的结果还不是很明显,需要分组用count()计数,取得不同连续值的次数SELECT uid,count(*) FROM(SELECT uid,(DAY(loadtime)-row_number() over(PARTITION BY uid ORDER BY uid) ) AS cnt FROM loadrecord) AS a GROUP BY uid,cnt;
#第三步#取得最大连续值#采用类似部门最高薪的方法 select max() group by SELECT uid, MAX(cnt) FROM(SELECT uid,count(*) AS cnt FROM(SELECT uid,(DAY(loadtime)-row_number() over(PARTITION BY uid ORDER BY uid) ) AS cnt FROM loadrecord) AS aGROUP BY uid,cnt) AS b GROUP BY uid;SELECT * from loadrecord WHERE row_number() over(partition by uid order by uid) ) AS cnt ;

About Me:小婷儿

● 本文作者:小婷儿,专注于python、数据分析、数据挖掘、机器学习相关技术,也注重技术的运用

● 作者博客地址:https://blog.csdn.net/u010986753

● 本系列题目来源于作者的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解

● 版权所有,欢迎分享本文,转载请保留出处

● 微信:tinghai87605025 联系我加微信群

● QQ:87605025

● QQ交流群py_data :483766429

● 公众号:python宝 或 DB宝

● 提供OCP、OCM和高可用最实用的技能培训

● 题目解答若有不当之处,还望各位朋友批评指正,共同进步

如果你觉得到文章对您有帮助,点击下方我的头像,赞赏我哦!

有您的支持,小婷儿一定会越来越好!

这篇关于【051】row_number() over() 查询各个用户最长的连续登陆天数?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1005955

相关文章

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

浅谈mysql的sql_mode可能会限制你的查询

《浅谈mysql的sql_mode可能会限制你的查询》本文主要介绍了浅谈mysql的sql_mode可能会限制你的查询,这个问题主要说明的是,我们写的sql查询语句违背了聚合函数groupby的规则... 目录场景:问题描述原因分析:解决方案:第一种:修改后,只有当前生效,若是mysql服务重启,就会失效;