微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用“分区依据”或“最大”?

如何解决如何使用“分区依据”或“最大”?

| 我有下表(my_data):
year |  X  |  Y
-----+-----+-----
2010 |  A  |  10
2011 |  A  |  20
2011 |  B  |  99
2009 |  C  |  30
2010 |  C  |  40
什么是最好/最小的sql语句,仅检索与最高年份相关的数据并按\'X \'进行分组,如下所示:
year |  X  |  Y
-----+-----+-----
2011 |  A  |  20
2011 |  B  |  99
2010 |  C  |  40
请注意,此结果表将在联接中使用。     

解决方法

        
select year,x,y
from (
      select year,y,max(year) over(partition by x) max_year
      from my data
      )
where  year = max_year
    ,        
select * from (
  select year,row_number() over (partition by x order by year desc ) rn 
  from my_data
) where rn = 1
    ,        您也可以随身携带并使用OUTER JOIN:
select t1.year,t1.x,t1.y
  from my_data t1
  left join my_data t2
    on t2.x = t1.x
   and t2.year > t1.year
 where t2.x is null
    ,        它比其他解决方案简单得多:
SELECT x,max(year),MAX(y) KEEP (DENSE_RANK FIRST ORDER BY year DESC)
  FROM table
  GROUP BY x
    ,        加里·迈尔斯(Gary Myers),您的解决方案不起作用,例如,对于值A,年份小于2010,并且该年份具有最大值。 (例如,如果存在行2005,A,50) 为了获得正确的解决方案,请使用以下内容。 (只是交换值)
SELECT x,max(y),MAX(year) KEEP (DENSE_RANK FIRST ORDER BY y DESC)
FROM test
GROUP BY x
    ,        您可以使用公用表表达式(CTE),也可以用于重复的行(如果需要) 执行计划是相同的,或多或少
;With my_data_cte as (
    SELECT [year],ROW_NUMBER() OVER (
        PARTITION BY x
        ORDER BY [year] desc) as rn
FROM [dbo].[my_data])
select [year],y from my_data_cte 
where rn = 1
    ,        
  -- I had a slightly different case and just wandering why this one should\'t work 
  SELECT my_data.x,my_data.y,my_data1.max_year 
  FROM my_data
  INNER JOIN 
  ( 
    SELECT x,max (year ) as max_year
    FROM my_data
    -- WHERE 1=1
    -- AND FILTER1=VALUE1
    GROUP BY my_data.x
  ) my_data1
  ON ( my_data.x = my_data1.x )
    ,        
select year,y 
 from my_data stable 
where stable.year = (select max(year) 
                     from my_data tables 
                     where tables.x = stable.x);
    ,        这也可以解决 从abc中选择greatest((e),(g),(c),(a),(b))作为最新日期     ,        最简单的是
Select * 
from table 
where year = (select max(year) from table)
除非有年份索引,否则可能会导致表扫描。但是带索引应该表现出色     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。