首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

连续操作(登录)数量(次数)最大的记录(用户)

昨晚上老同事聚会,一个同事说道一个面试问题没有一个人做出来,就是求连续日期登录次数最大的用户,同事说借助 rownumber即可求解,由于是喝酒聊天,也没有说详细的解决过程。...登录时间里面有详细的时分秒数据,而我们的题目只要求连续的天数,所以使用DATEDIFF函数可以解决, DATEDIFF(d,LoginTime,getdate()) as diffDate , 有多个用户都在登录...desc) as rn 关键问题来了,如何求得连续登录情况?...开始动手,先构造一个表,插入初始数据: /* 求连续登录次数最多的用户 */ create table UserLoginInfo( ID int IDENTITY primary key,...,或者求连续登录15天的用户(比如QQ的签到功能),是不是很熟悉呢?

3.1K70

MySQL 连续登录通用计算模型

某音某团某节面试时,经常会问到连续登录问题,这个问题看似简单,属于那种“一看就会,一做就懵”的问题,网上分享的一些解题思路,逻辑上比较复杂,今天笔者来分享一种简洁而通用的解题思路,应付此类问题变得游刃有余...算法介绍 这里主要用到了一个算法:连续日期与固定日期的时间间隔递增,而在日期表中,大于等于当前日期的日期行数又是递减的,两者相加会得到一个固定值,如果相加之和出现变化,说明出现了不连续日期,详情可看下图...初识面试题 下面,咱们就应用这个算法来解一下这个面试题: 有用户表行为记录表t_act_records表,包含两个字段:uid(用户ID),imp_date(日期) 计算2021年每个月,每个用户连续登录的最多天数...计算2021年每个月,连续2天都有登录的用户名单 计算2021年每个月,连续5天都有登录的用户数 构造表mysql如下: DROP TABLE if EXISTS t_act_records; CREATE...,flag是连续日期的标志位,check_period 是核查的周期(可以是周week()、月month()、年year(),或者忽略此维度,核查所有的登录日期),continous_days 是核查周期内的连续登录日期天数

79730
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    数仓面试——连续登录问题

    Hi, 我是小萝卜算子 一、简介 连续登录问题,是一个经典sql,本文从易到难,简单拓展,有更好方法的同学,欢迎私下交流 二、表结构(去过重的) CREATE TABLE `user_login`(...2:然后根据主表的id,和登录时间分组,分组后数量正好是3天的,说明连续三天时间都有登录 3:根据步骤二的结果去重,获取结果 方法二:巧用窗口函数row_number SELECT tmp2.id...flag = 1 GROUP BY tmp2.id 详解: 1:因为是固定的3天,所以可以采用lag(lead)方法,求出前面第二个的日期与当前的日期差 2:根据步骤一的结果,判断如果日期差等于2,则是连续登录...2:如果日期差为1,则连续登录,记为0,否则记录当前登录日期 3:利用窗口函数max,获取用户登录基准日期 4:根据基准日期分组,过滤出大于等于3天的数据 5:根据步骤四结果去重,获得最后结果 五、拓展...连续登录问题,其实可扩展为划分组别的问题 如果是时间不固定,比如求每个用户最大连续登录天数,那么方法一和三就失效了 如果仅仅是题目要求,求固定连续登录天数,那么个人更倾向于方法三 方法四的扩展性更强,

    1.1K30

    Spring Security笔记:登录尝试次数限制

    今天在前面一节的基础之上,再增加一点新内容,默认情况下Spring Security不会对登录错误的尝试次数做限制,也就是说允许暴力尝试,这显然不够安全,下面的内容将带着大家一起学习如何限制登录尝试次数...新增一张表T_USER_ATTEMPTS,用来辅助记录每个用户登录错误时的尝试次数 ?...D_ID 是流水号 D_USERNAME 用户名,外建引用T_USERS中的D_USERNAME D_ATTEMPTS 登录次数 D_LASTMODIFIED 最后登录错误的日期 二、创建Model/DAO...,登录尝试次数达到阈值3时,通过抛出异常LockedException来通知上层代码。...五、运行效果 连续3次输错密码后,将看到下面的提示 ? 这时如果查下数据库,会看到 ? 错误尝试次数,在db中已经达到阀值3 ?

    5.3K50

    关于连续登录的问题探究

    经常会在数据统计中取筛选连续性的数据,比如筛选连续三个月都登录的用户, 数据形式如下: 1 111 222 333 2 111 3 111 222 4 111 444 大体的意思就是1 2 3 4...代表月份1,2,3,4 111,222,333,444代表用户 1 111 222 333 代表一月份用户111 222 333登录了。...以此类推 如果要查找连续三个月登录的用户,我把数据结构进行了改进 1 111 1 222 1 333 2 111 3 111 3 222 4 111 4 444 这样就更符合关系型了。...3 111 4 444 4 --利用最大月份 减去 最小月份 +1 (不跨年的情况下),然后除去关联的月份数,如果是1,那就证明连续几个月就登录了...连续4个月的 SQL> select id2,max(id1),min(id1),count(*),max(id1)-min(id1)+1 from test group by id2 having

    836120

    用SQL计算用户连续登录天数

    上次我们根据用户创建账号和登录日志进行了《用SQL进行用户留存率计算》,今天我们继续用这份用户登录日志来计算用户连续登录天数。 1....数据预览 这里我们用到的是用户登录的日志,其中用户每天可能存在多次登录。 用户登录日志 用户登录 以上案例数据 后台回复 955 可以在SQL文件夹里data领取 2....《『数据分析』pandas计算连续行为天数的几种思路》 《利用Python统计连续登录N天或以上用户》 今天,我们用SQL来进行本次的操作,大致分为以下几步: 数据去重 SELECT DISTINCT...(DATE_SUB),并按照用id和差值进行分组计数(这就是用户的连续登录天数) SELECT role_id , DATE_SUB(date,INTERVAL sort DAY) d_group ,...role_login ) temp_1 ) temp_2 GROUP BY role_id, DATE_SUB(date,INTERVAL sort DAY) 最后取每个用户id的连续登录天数的最大值即可

    2.9K30

    MySQL查询连续数据

    查询连续记录并对这些连续数据统计取出指定连续次数的记录,这类操作并不多,但出现时会比较棘手。...查询思想是: 顺序行号 - 减首差值 = 连续差块 顺序行号 如同 Oracle 中的 rownum 但MySQL目前还没有这个功能,所以只能通过局部变量来实现, 减首差值 就是每条记录与最开始记录的差...(需要保证这个差值与顺序行号递增值相同,当然如果本来就是自增值则不需要单独计算) 只要 顺序行号与减首差值保持相同递增值则 连续差块 值相同,就可以统计出连续长度 示例表:(以简单的签到表为例) create...查询的思路是: 1.提取出全表用户每次打卡记录与第一次打卡记录的差值但按用户与日期正排序 2.增加一个局部变量rownum与上面查询数据进行连查 3.在结果字段集里使用日期差值减去自增顺序行号值得到连续差块...4.通过分组用户与连续差块获取连续签到次数 5.通过having来提取超过6次签到的用户

    4.6K20

    如何定义和统计用户的登录次数

    假设你去网吧包夜,登录并浏览了某个图片视频网站,连续看了七天七夜,这算登录几次呢? 如果你定义这是一次登录,那么按照登录来统计用户的活跃度就会有问题,这个用户明明活跃了七天,却只记录了一次活跃。...这里要想统计真正的活跃,就要看看,这个用户在七天内的 PV,也就是说,我们要拿到带有用户登录态的页面浏览数据,才能统计真正的活跃,只看登录次数是不行的。...那么,这种情况下,如果想记录为两次活跃,只看登录次数也是不行的。 所以你看,严格意义上来说,用户的登录次数,就是输入用户名密码,并且验证通过的次数。但对于业务来说,这个数据意义并不大。...综上所述,你说的登录次数,可能跟我说的登录次数,完全不是一回事,所以,如果要统计你说的登录次数,就要清楚地描绘出用户的具体行为,比如带有登录态的时候,每次打开我们的网站,就算一次登录,类似这种。...这样一来,登录次数的口径,其实就变成了业务指标,所以你也不用太纠结技术上是什么定义了,了解一下原理就够了。

    4.3K30

    MySQL查询连续打卡信息?

    导读 最近多次看到用SQL查询连续打卡信息问题,自己也实践一波。抛开问题本身,也是对MySQL窗口函数和自定义变量用法的一种练习。...01 建表 所用数据库为MySQL8.0,简单而不失一般性,建立一个仅有记录id、用户id、日期和打卡标记共4个字段的数据表。...MySQL分类排名问题)问题在8.0中运用窗口函数就非常简单。...各用户连续打卡记录 当然,如果是MySQL8.0以下版本,是没有lead()窗口函数可以直接调用的,次此时可借助连接查询或者子查询,设定连接条件是表1和表2用户相同、日期相差为1即可。...05 总结 本文对MySQL中查询用户连续打卡这一问题进行了分析,主要是基于自定义变量的方式,实现了以下问题: 查询各用户每天的连续打卡信息(包括未打卡时记为0) 查询各用户最近连续打卡信息 查询各用户历史最长打卡信息

    4.1K10

    数仓面试——连续登录问题进阶版

    Hi, 我是小萝卜算子 一、引入 紧接上一篇文章:数仓面试——连续登录问题 表结构和数据一致 需求有所升级: 中间间隔一天,也算连续登录,求出连续4天登录的用户id(因为样例中1001用户连续3天登录,...但是升级后,则可视为连续4天登录) 二、思考 由于间隔一天也算连续登录 数仓面试——连续登录问题中方法一/二/三的方式将不再有效,因为过滤条件变成不固定的筛选日期了 方法四依然有效,只需要将flag...,过滤出次数大于等于4的数据 6:按照用户分组去重,获得最终结果 方法二:采用超过两天的登录间隔为分界线分组 SELECT id FROM ( SELECT id, max_dt_line...,比较当前日期与上一个登录日期的差 2:如果日期差小于等于2,则连续登录,记为0,否则记录当前登录日期 3:利用窗口函数max,获取用户登录基准日期(连续登录为0,所以max为前标线) 4:根据基准日期分组...0,不是则为当前登录日期,然后利用max窗口函数,按登录时间升序,获得分组的日期基准 方法三设定连续登录基准线,连续登录为0,不是则为1,然后添加一个自增序列,那么就可以把1的和最后一条提取出来,然后计算前后的序列差

    1.2K40

    K 连续位的最小翻转次数(差分思想)

    题目 在仅包含 0 和 1 的数组 A 中,一次 K 位翻转包括选择一个长度为 K 的(连续)子数组,同时将子数组中的每个 0 更改为 1,而每个 1 更改为 0。...返回所需的 K 位翻转的次数,以便数组没有值为 0 的元素。如果不可能,返回 -1。 示例 1: 输入:A = [0,1,0], K = 1 输出:2 解释:先翻转 A[0],然后翻转 A[2]。...使数组互补的最少操作次数(差分思想) 差分思想,用差分数组记录区间翻转情况 左端点翻转一次的话,长度为 K 的区间左端点+1,右端点+1的位置 -1 差分数组的前缀和为每个位置的翻转次数,翻转次数为偶数的话...int K) { int n = A.size(); vector flip(n+1, 0); int presum = 0;//每个位置的翻转次数

    42010

    mysql设密码_MySQL登录

    MySQL默认是没有密码的,为了安全,所以需要手动设置密码,操作过程如下 没有密码是设置密码: [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2VyWrQhu-1646491085519...root密码,修改完成后,需要将本行注释掉 #port port=3306 #set basedir to your install path basedir=C:\\Program Files\\mysql...-5.7.31-winx64 #set datedir to your path datadir=C:\\Program Files\\mysql-5.7.31-winx64\\data (2)停止数据库...,再开启数据库 net stop mysql;net start start mysql (3)再进行登录,能够无密码登录 (4)进入数据后,再次修改密码 user mysql; update...authentication_string = password(“新密码”),password_last_changed=now() where user=“root”; (5)改回配置文件 (5)再重启数据库,再是使用新密码登录即可

    4K30
    领券