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

大庆公司做网站培训心得体会2000字

大庆公司做网站,培训心得体会2000字,溧水城市建设招标网站,日本 色彩网站文章目录 查询最近一笔有效订单 一、题目 二、分析 三、SQL实战 四、样例数据参考 查询最近一笔有效订单 一、题目 现有订单表t5_order,包含订单ID,订单时间,下单用户,当前订单是否有效。 请查询出每笔订单的上一笔有效订…

文章目录

查询最近一笔有效订单

一、题目

二、分析

三、SQL实战

四、样例数据参考 


查询最近一笔有效订单

一、题目

现有订单表t5_order,包含订单ID,订单时间,下单用户,当前订单是否有效。

请查询出每笔订单的上一笔有效订单,注意不是每笔订单都是有效的。

样例数据:

目标结果:

二、分析

本题是查询上一条记录的升级版本,所以考察的lag()函数,但是我们也不知道上一单是有效还是无效,所以这个题目难度就增加了很多。

维度评分
题目难度⭐️⭐️⭐️⭐️⭐️
题目清晰度⭐️⭐️⭐️⭐️
业务常见度⭐️⭐️⭐️⭐️

三、SQL实战

1、先查询出有效订单,然后计算出每笔有效订单的上一单有效订单。

查询语句:

select ord_id,ord_time,user_name,is_valid,lag(ord_id) over (partition by user_name order by ord_time asc) as last_valid_ord_id
from (select ord_id,ord_time,user_name,is_validfrom t5_orderwhere is_valid = 1) t;

查询结果:

2、原始的明细数据与新的有效订单表按照用户进行关联,有效订单表的订单时间大于等于原始订单表。

查询语句:

with tmp as (-- 有效订单及其上一单有效记录select ord_id,ord_time,user_name,is_valid,lag(ord_id) over (partition by user_name order by ord_time asc) as last_valid_ord_idfrom (select ord_id,ord_time,user_name,is_validfrom t5_orderwhere is_valid = 1) t)
select t1.*,t2.*
from t5_order t1
left join tmp t2 on t1.user_name = t2.user_name
where t1.ord_time <= t2.ord_time;

查询结果:

3、使用row_number,原始订单记录表中的user_name、ord_id进行分组,按照有效订单表的时间排序,增加分组排序。

查询语句:

with tmp as (-- 有效订单及其上一单有效记录select ord_id,ord_time,user_name,is_valid,lag(ord_id) over (partition by user_name order by ord_time asc) as last_valid_ord_idfrom (select ord_id,ord_time,user_name,is_validfrom t5_orderwhere is_valid = 1) t)
select t1.*,t2.*,row_number() over (partition by t1.ord_id,t1.user_name order by t2.ord_time asc) as rn
from t5_order t1
left join tmp t2 on t1.user_name = t2.user_name
where t1.ord_time <= t2.ord_time;

我们可以看出,最终我们需要的就是rn=1 的记录。 

查询结果:

4、去除冗余字段,筛选rn=1 的记录。

查询语句:

with tmp as (-- 有效订单及其上一单有效记录select ord_id,ord_time,user_name,is_valid,lag(ord_id) over (partition by user_name order by ord_time asc) as last_valid_ord_idfrom (select ord_id,ord_time,user_name,is_validfrom t5_orderwhere is_valid = 1) t
)
select * from
(select t1.*,t2.*,row_number() over (partition by t1.ord_id,t1.user_name order by t2.ord_time asc) as rn
from t5_order t1
left join tmp t2 on t1.user_name = t2.user_name
where t1.ord_time <= t2.ord_time) tt
where tt.rn = 1;

查询结果:

四、样例数据参考 

--建表语句
create table t5_order
(ord_id bigint COMMENT '订单ID',ord_time string COMMENT '订单时间',user_name string COMMENT '用户名',is_valid int COMMENT '订单是否有效'
);
-- 数据插入
insert into t5_order(ord_id,ord_time,user_name,is_valid)
values(1,'2024-08-11 12:01:03','姬小满',1),(2,'2024-08-11 12:02:06','姬小满',0),(3,'2024-08-11 12:03:15','姬小满',0),(4,'2024-08-11 12:04:20','姬小满',1),(5,'2024-08-11 12:05:03','姬小满',1),(6,'2024-08-11 12:01:02','甄姬',1),(7,'2024-08-11 12:03:03','甄姬',0),(8,'2024-08-11 12:04:01','甄姬',1),(9,'2024-08-11 12:07:03','甄姬',1);

  • 📢博客主页:https://lansonli.blog.csdn.net
  • 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!
  • 📢本文由 Lansonli 原创,首发于 CSDN博客🙉
  • 📢停下休息的时候不要忘了别人还在奔跑,希望大家抓紧时间学习,全力奔赴更美好的生活✨
http://www.yidumall.com/news/97025.html

相关文章:

  • 成都网站建设公司排行seo推广优化服务
  • 国际 网站制作公司seo工资一般多少
  • 我想自己做网站seo什么意思
  • 绵阳网站建设优化seo服务公司上海
  • 景安 怎么把网站做别名seo搜索引擎优化知乎
  • 会设计网站怎么做兼职百度推广手机登录
  • 太原百度做网站多少钱网络营销运营推广
  • 用手机能创建网站吗顶尖文案
  • 企业策划营销中心谷歌推广优化
  • 注册网站多久seo站点是什么意思
  • 个人网站如何做淘客网站枸橼酸西地那非片功效效及作用
  • 开发公司截留占用住宅专项维修资金dz论坛如何seo
  • 轻松网站建设优化营商环境的意义
  • 学做网站要学什么语言谷歌搜索入口 镜像
  • 日本真人做爰无遮挡视频免费网站怎么做网站优化
  • web网站开发能实现上传文件石家庄百度搜索引擎优化
  • 360网站怎么做链接html网页制作app
  • 专业网站建设在哪里谷歌搜索引擎网页版入口
  • 自己做的网站不备案不能访问吗互联网广告推广是什么
  • 外贸公司取名字参考大全上海seo培训中心
  • 开网络公司做网站挣钱么西安seo计费管理
  • 公司怎样做网站关键词seo排名优化推荐
  • 学做投资网站好seo发包软件
  • 做网站哪些方面会侵权获客引流100种方法
  • 如何做网站的搜索栏百度知道一下首页
  • 出口外贸营销网站企业微信scrm
  • 福州营销网站建设模板seo模拟点击软件
  • 南宁网站推广公司东莞疫情最新消息今天又封了
  • 网站开发招聘实习如何制作网页最简单的方法
  • 扶贫基金会网站建设是哪家公司百度推广助手电脑版