SQL面试题练习 —— 最后一次登录停留时长

news2024/11/16 23:29:47

目录

  • 1 题目
  • 2 建表语句
  • 3 题解

题目来源:腾讯微信。

1 题目


有一张用户登录日志表ods_usr_login_log, 包含user_id(用户id)、ds(登录时间)以及stay_time(停留时长,单位:ms)

问题:计算每个用户每天最后一次登录的停留时长。

样例数据

-- 输入
user_id      ds           stay_time 
001   2024-07-01 10:10:06   10
001   2024-07-01 13:10:06   5
001   2024-07-02 15:10:06   20
-- 输出
user_id      dt      stay_time 
001       2024-07-01       5 
001       2024-07-02       20

2 建表语句


create table ods_usr_login_log (
user_id varchar(20),
ds varchar(20),
stay_time bigint
);
INSERT INTO ods_usr_login_log VALUES 
('001','2024-07-01 10:10:06',10),
('001','2024-07-01 13:10:06',5),
('001','2024-07-02 15:10:06',20),
('002','2024-07-01 16:11:06',15),
('002','2024-07-01 18:11:06',25)
;

3 题解


先按照用户id和日期进行分组,登录时间进行逆序排列,计算对应的排名,然后获取排名为1的数据,即为题目所求

select 
    user_id,
    dt,
    stay_time
from (
    select 
        user_id, 
        str_to_date(ds, '%Y-%m-%d') as dt,
        stay_time,
        row_number() over(partition by user_id, str_to_date(ds, '%Y-%m-%d')  order by ds desc) as rn
    from ods_usr_login_log
) t
where rn = 1
;

执行结果

在这里插入图片描述

在 STR_TO_DATE 函数中,日期格式参数 (‘%Y-%m-%d’) 中的字母是区分大小写的。具体来说:

  • %Y: 表示四位的年份,例如 2024。
  • %m: 表示两位的月份,例如 08 表示八月。
  • %d: 表示两位的日期,例如 15 表示十五号。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1991725.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

再等等,iPhone 17系列大革新,即将带来颠覆性的升级

自从苹果在2021年的iPhone 13 Pro系列中引入了ProMotion自适应刷新率技术以来,这项技术便成为了高端智能手机显示技术的重要标志。 如今,随着iPhone 17系列即将登场,我们有望见证这项技术向下一代更广泛的设备拓展。不仅如此,iPh…

每日一题~ abc 365 E 异或运算(拆位+贡献)

处理位运算常用的方法: 拆位法(一位一位的处理,通常题目中会给出元素的最大是2的的多少次幂,当然也有给10的次幂的,自己注意一下就可以了) 常用的思想 : 算贡献。 异或的性质: A^A0 …

抖音外卖区域服务商有哪些城市开放了?搭建本地生活系统抢先入局的成功率如何?

随着多家互联网大厂对本地生活重视程度的不断提高,本地生活服务商逐渐成为众多创业者心目中的首选赛道。在此背景下,抖音外卖区域服务商的申请通道一经开放便引发了一阵申请热潮。 毕竟,根据艾瑞咨询数据预测,到2025年&#xff0…

Linux5.15.71编译问题处理

目录 1 编译环境及源码版本2 移植Linux 5.15.71遇到问题2.1 imx-sdma 20ec000.dma-controller: Direct firmware load for imx/sdma/sdma-imx6q.bin failed with error -22.2 cfg80211: failed to load regulatory.db 1 编译环境及源码版本 ​ 1. uboot-alientek-v2022.04 ​…

红酒与亚洲菜肴:品味东方韵味

当西方的红酒遇上东方的菜肴,一场跨越地域与文化的味蕾盛宴就此展开。洒派红酒(Bold & Generous)与亚洲菜肴的相遇,不仅是一场美食的邂逅,更是一次对东方韵味的深度品味。 一、红酒的醇厚与亚洲菜肴的精致 红酒&…

【Unity程序】和【控制台程序】连接【asp.net core的websocket服务】(1)——在编辑器中运行

一、说明 1、本文实验内容所涉及的开发环境说明: win11VisualStudio2022(.Net6.0)Unity2021.3.40 2、本文参考资料 【1】NativeWebSocketUnity包: https://github.com/endel/NativeWebSocket 【2】asp.net core架设websocket国…

【安卓】SharedPreferences存储

SharedPreferences使用键值对的方式来存储数据的。也就是说,当保存一条数据的时候,需要给这条数据提供一个对应的键,这样在读取数据的时候就可以通过这个键把相应的值取出来。而且SharedPreferences还支持多种不同的数据类型存储,…

游戏原画可节省60-80%工时,大厂在用AI做什么

AIGC技术的迭代,是不是太快了点? 前年年中还是光速出图的Stable Diffusion,到年底就有了可以媲美真人的文本处理模型ChatGPT,今年开年又蹦出来了可以凭空变出视频、动画的Sora……我们对技术升级的认知被一次次刷新,同…

BHGMall生活超市天通苑店盛大开业,多重好礼只等你来

据悉8月10日,BHGMall生活超市天通苑店焕新开业,催旺“七夕浪漫经济”造福社区百姓,不仅提供助老服务,还有超值福利、多重好礼,倡导天天有低价,以实惠的价格买到优质的商品,提升居民幸福感和城市…

解题思考:为什么Java中使用Arrays.stream()创建流处理数组通常会增加开销,提高时间复杂度?

目录 问题描述:问题回答: 问题描述: 在解决力扣上的: 3131. 找出与数组相加的整数 I 时,使用传统遍历会比创建流处理数组的时间复杂度更低。 1.传统遍历代码: class Solution {public int addedInteger(i…

大模型与数据分析的融合:创新与发展的新机遇

大模型与数据分析的融合:创新与发展的新机遇 前言大模型与数据分析的融合 前言 大模型与数据分析的融合正成为推动企业发展的关键力量。大模型在数据分析领域展现出了强大的能力。它能够以接近人类的水平理解和处理自然语言,快速、准确地解析大量非结构…

vue实现PC端图片放大缩小可鼠标拖动,鼠标滚轮控制放大缩小完整代码付效果图

vue实现图片放大缩小可鼠标拖动&#xff0c;鼠标滚轮控制放大缩小完整代码付效果图 效果图&#xff1a; 创建一个ImageViewer 组件&#xff0c;并且在当前页面引用完整代码如下&#xff1a; 代码引用&#xff1a; <template><view><image-viewer :imageUrl&q…

大数据-69 Kafka 高级特性 物理存储 实机查看分析 日志存储一篇详解

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…

SOMEIP_ETS_022:echoStaticUINT8Array_One_Dimensional

测试目的&#xff1a; 确保DUT能够正确处理一维静态UINT8数组参数&#xff0c;并且在发送和接收过程中保持参数值和顺序不变。 描述 本测试用例将验证DUT在处理包含一维静态UINT8数组参数的SOME/IP消息时&#xff0c;是否能够准确地发送和接收这些参数&#xff0c;确保返回的…

[数据结构] 万字解析排序算法

文章目录 快速排序双指针法整体排序过程整理选择基准值&#xff08;Pivot&#xff09;单趟划分&#xff08;Partitioning&#xff09;递归分治&#xff08;Divide and Conquer&#xff09;终止条件合并 整体代码实现为什么相遇位置一定是小值&#xff1f;情况 1: 右指针j找到了…

HexView 刷写文件脚本处理工具-基本功能介绍(七)-导出VBF/GM/GM-FBL

导出Ford VBF数据容器 VBF文件格式是Ford和Volvo Cars使用的多功能二进制格式。此文件的输出基于“Versatile Binary Format”规范,版本从2.2至2.5。在对话框中输入的所有值将被写入INI文件。INI文件也可以用于命令行选项,以在不需要用户输入的情况下生成输出。 导出GM数据…

网卡与Linux网络结构(中)

1 socket数据结构 socket源码 socket结构体是操作系统网络编程接口的一个核心组件。在操作系统中&#xff0c;socket结构体定义了一个网络连接的抽象&#xff0c;包括文件描述符、地址信息、连接状态等。 socket结构体代码位于<include/linux/net.h> struct socket { s…

android13 串口编号修改 串口名修改

总纲 android13 rom 开发总纲说明 目录 1.前言 2.技术分析 别名定义的语法规则 3.修改示例 使用别名 注意事项 4.不生效分析 5.编译查看 6.其他方法 7.彩蛋 1.前言 更改Android设备的串口编号涉及对系统深层次的配置进行修改,通常是为了解决硬件兼容性问题或满足特…

MySQL:约束

目录 1、约束 1.1 约束类型 2、非空约束 2.1 没有指定not null 2.2 指定not null 3、唯一约束 3.1 没有指定unique 3.2 指定unique 4、默认约束 5、主键约束 5.1 主键 5.2 主键自增类型 5.2.1 主键自增全列插入 5.2.2 主键自增指定列插入 5.3 复合主键 6、外键约…

探秘充电桩测试负载箱

随着电动汽车的普及&#xff0c;充电桩已经成为了城市中不可或缺的一部分。为了保证充电桩的质量和安全性&#xff0c;对其进行严格的测试是必不可少的。而在这个过程中&#xff0c;充电桩测试负载箱扮演着至关重要的角色。那么&#xff0c;什么是充电桩测试负载箱&#xff1f;…