wangminjianjy 2016-11-16 03:44 采纳率: 66.7%
浏览 2932
已采纳

sqlserver 取每个时间段多行多列的最大值

ID Time A B C
1 2000-01-01 10:10:10 20 30 15
2 2000-01-01 11:20:20 30 15 40
3 2000-01-01 12:30:30 30 20 10
4 2000-01-02 10:10:10 30 40 25
5 2000-01-02 11:20:20 20 50 60

表格就像上面一样,现在需要求时间段内A、B、C的最大值
结果像
Time max
2000-01-01 11:20:20 40
2000-01-02 11:20:20 60

  • 写回答

2条回答 默认 最新

  • 全栈极简 博客专家认证 2016-11-16 08:07
    关注
    select convert(char(10),time,120) 日期,
    (case when MAX(A)>MAX(B) and MAX(A)>MAX(C) then MAX(A) 
    when MAX(B)>MAX(A) and MAX(B)>MAX(C) then MAX(B) 
    when MAX(C)>MAX(A) and MAX(C)>MAX(B) then MAX(C) 
    end)ABC最大值
    from ttt group by convert(char(10),time,120)
    
    select * from ttt 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 如何能达到用ping0.cc检测成这样?如图
  • ¥15 关于#DMA固件#的问题,请各位专家解答!
  • ¥15 matlab生成的x1图不趋于稳定,之后的图像是稳定的水平线
  • ¥15 请问华为OD岗位的内部职业发展通道都有哪些,以及各个级别晋升的要求
  • ¥20 微信小程序 canvas 问题
  • ¥15 系统 24h2 专业工作站版,浏览文件夹的图库,视频,图片之类的怎样删除?
  • ¥15 怎么把512还原为520格式
  • ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
  • ¥15 求高通平台Softsim调试经验
  • ¥15 canal如何实现将mysql多张表(月表)采集入库到目标表中(一张表)?