cte结合partition - 一道复杂的sql面试题

简介: 今天别人问了我一道复杂的sql面试题, 题目是这样的: --code     价格                  时间'0010'     100      '2012-08-01 00:00:00.

今天别人问了我一道复杂的sql面试题, 题目是这样的:

 

--code     价格                  时间
'0010'     100      '2012-08-01 00:00:00.000'
'0010'     100      '2012-08-02 00:00:00.000'
'0010'     100      '2012-08-03 00:00:00.000'
'0010'     100      '2012-08-05 00:00:00.000'
'0012'     120      '2012-08-07 00:00:00.000'
'0012'     120      '2012-08-08 00:00:00.000'

 

上面是原始数据集,

由上面的数据集,根据时间连续原则, 需要得到下面的结果集

 

--结果集
--code     价格        开始时间     结束时间
'0010'     100      '2012-08-01'   '2012-08-03'
'0010'     100      '2012-08-05'   '2012-08-05'
'0012'     120      '2012-08-07'   '2012-08-08'

 

建表语句如下:

CREATE  TABLE  [ dbo ]. [ MyOrder ](
     [ code ]  [ varchar ]( 10NULL,
     [ price ]  [ int ]  NULL,
     [ time ]  [ datetime ]  NULL
ON  [ PRIMARY ]

GO

 

 

解决代码如下, 一会儿再给你分析我的思路

with cteMinOrder
as
(
     select code,  MIN(time)  as min_time
     from MyOrder
     group  by code
),
cteMyOrder
as
(
     SELECT  *, Rank() 
         Over(Partition  by code  Order  BY time)  AS rownum    
     FROM MyOrder
),
cteCompOrder
as
(
     select a.code, a.price, a.time, a.rownum, 
        b.min_time,  DATEADD( day, rownum  -  1, b.min_time)  AS ctime
     from cteMyOrder a  left  join cteMinOrder b
      on a.code  = b.code
)


select code, price,  MIN(time)  as start_time,  MAX(time)  as end_time
from cteCompOrder
where time =ctime
group  by code, price
union  all
select code, price,  MIN(time)  as start_time,  MAX(time)  as end_time
from cteCompOrder
where time !=ctime
group  by code, price
order  by code

 

 

目录
相关文章
|
3月前
|
SQL 数据库
SQL面试50题------(初始化工作、建立表格)
这篇文章提供了SQL面试中可能会遇到的50道题目的建表和初始化数据的SQL脚本,包括学生、教师、课程和成绩表的创建及数据插入示例。
SQL面试50题------(初始化工作、建立表格)
|
6月前
|
SQL 关系型数据库 MySQL
MYSQL-SQL语句性能优化策略以及面试题
MYSQL-SQL语句性能优化策略以及面试题
141 1
|
3月前
|
SQL
sql面试50题------(1-10)
这篇文章提供了SQL面试中的前10个问题及其解决方案,包括查询特定条件下的学生信息、教师信息和课程成绩等。
sql面试50题------(1-10)
|
14天前
|
SQL 缓存 监控
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
本文详细解析了数据库、缓存、异步处理和Web性能优化四大策略,系统性能优化必知必备,大厂面试高频。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
|
3月前
|
SQL
sql面试50题------(11-20)
这篇文章提供了SQL面试中的50道题目,其中详细解释了11至20题,包括查询与学号为“01”的学生所学课程相同的学生信息、不及格课程的学生信息、各科成绩统计以及学生的总成绩排名等问题的SQL查询语句。
|
3月前
|
SQL
sql面试50题------(21-30)
这篇文章是SQL面试题的21至30题,涵盖了查询不同老师所教课程的平均分、按分数段统计各科成绩人数、查询学生平均成绩及其名次等问题的SQL查询语句。
sql面试50题------(21-30)
|
4月前
|
存储 SQL 索引
面试题MySQL问题之使用SQL语句创建一个索引如何解决
面试题MySQL问题之使用SQL语句创建一个索引如何解决
53 1
|
5月前
|
SQL 大数据
常见大数据面试SQL-每年总成绩都有所提升的学生
一张学生成绩表(student_scores),有year-学年,subject-课程,student-学生,score-分数这四个字段,请完成如下问题: 问题1:每年每门学科排名第一的学生 问题2:每年总成绩都有所提升的学生
|
5月前
|
SQL 关系型数据库 MySQL
sql面试题库
sql面试题库
|
4月前
|
SQL Java 关系型数据库
Java面试题:描述JDBC的工作原理,包括连接数据库、执行SQL语句等步骤。
Java面试题:描述JDBC的工作原理,包括连接数据库、执行SQL语句等步骤。
66 0

热门文章

最新文章

下一篇
无影云桌面