一道看似简单的sql需求却难倒各路高手 - 你也来挑战下吗

听说这题难住大批高手,你也来试下吧。

原始数据

select * from t_jeff t 

简单排序后数据

select  *  from  t_jeff t  order   by  t.VINNumber,t.channelid  desc

需求,根据VINNumber分组(每对连接一起) ,再根据ChannelID倒序

1、VINNumber同组的放一起
2、组之间排序逻辑:按照每组ChannelID最大值 倒序
3、组内排序:按照ChannelID倒序。
结果需要排列如图

 
创建脚本
  1. CREATE TABLE t_jeff (
      id int NOT NULL,
      VINNumber varchar(255) DEFAULT NULL,
     ChannelID varchar(255) DEFAULT NULL,
      TimeStamp datetime DEFAULT NULL,
      PRIMARY KEY (id)
    ) ;
    INSERT INTO t_jeff VALUES ('1', 'Group3', '3', '2015-05-27 00:00:00');
    INSERT INTO t_jeff VALUES ('2', 'Group2', '5', '2015-05-23 00:00:00');
    INSERT INTO t_jeff VALUES ('3', 'Group1', '4', '2015-05-25 00:00:00');
    INSERT INTO t_jeff VALUES ('4', 'Group2', '3', '2015-05-29 00:00:00');
    INSERT INTO t_jeff VALUES ('7', 'Group1', '2', '2015-05-30 00:00:00');
怎么样,有思路吗,答案会在28号中午公布。
 

答案(通用)

1
2
3
4
SELECT i.* FROM (
     SELECT VINNumber, max (j.ChannelID) AS MAXID FROM t_jeff j GROUP BY j.VINNumber
) m
INNER JOIN t_jeff i ON i.VINNumber=m.VINNumber ORDER BY m.MAXID DESC ,i.VINNumber, i.ChannelID DESC ;

思路

先分组找出ChannelID的最大值,然后把它当作一个表,再进行关联排序

SELECT VINNumber,max(j.ChannelID) AS MAXID FROM t_jeff j GROUP BY j.VINNumber (当作一个表)

这里要注意的是最后排序的顺序 

1
ORDER BY m.MAXID DESC ,i.VINNumber, i.ChannelID DESC ; (这三个排序一个都不能少)

总结

大部分博友的答案思路是对的,但后面排序有缺漏。统计了下,博友的答案里面完全符合题目要求的有4个,另外mssql里面的写法有好几种,而且答对的也有几个。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值