当前位置: 代码迷 >> Sql Server >> 之前问了一个分组查询的有关问题。还是这个,难度增加了点
  详细解决方案

之前问了一个分组查询的有关问题。还是这个,难度增加了点

热度:49   发布时间:2016-04-24 20:11:50.0
之前问了一个分组查询的问题。还是这个,难度增加了点


vcPart_id     vcBegin     vcSupplier_id
 091010D011     20120401     1350
 091010D011     20120701     1350 
 091010D011     20121001     1350
 091010D011     20121101     1350
 091010D011     20130101     1350
 0911102100     20120401     1350
 0911102100     20120701     1350 
 0911102109     20121001     1350
 0911102109     20121101     1350
 0911102109     20130101     1350
 112120T031     20120401     1001
 112120T031     20120701     1001 
 112120T031     20130101     1001
 112120T032     20120801     1001
 112120T032     20130101     1001
 120000T150     20120401     1001
 120000T150     20120701     1001 
 120000T150     20130101     1001
 120000T160     20120401     1001
 120000T160     20120701     1001 


以上是表结构。
 想要得到的结果是vcPart_id相同的数据中vcBegin最大的和第二大的数据集
 既以下结果:
vcPart_id      vcBegin      vcSupplier_id
 091010D011     20130101     1350
 091010D011     20121101     1350
 0911102100     20120701     1350
 0911102100     20120401     1350 
 0911102109     20130101     1350
 0911102109     20121101     1350
 112120T031     20130101     1001
 112120T031     20120701     1001 
 112120T032     20130101     1001
 112120T032     20120801     1001
 120000T150     20130101     1001
 120000T150     20120701     1001 
 120000T160     20120701     1001
 120000T160     20120401     1001
求指点。谢谢了 
数据 结构

------解决方案--------------------
少了个DESC
----------------------------
-- Author  :DBA_Huangzj(發糞塗牆)
-- Date    :2013-10-17 11:37:35
-- Version:
--      Microsoft SQL Server 2012 (SP1) - 11.0.3128.0 (X64) 
-- Dec 28 2012 20:23:12 
-- Copyright (c) Microsoft Corporation
-- Enterprise Edition (64-bit) on Windows NT 6.2 <X64> (Build 9200: ) (Hypervisor)
--
----------------------------
--> 测试数据:[huang]
if object_id('[huang]') is not null drop table [huang]
go 
create table [huang]([vcPart_id] varchar(10),[vcBegin] datetime,[vcSupplier_id] int)
insert [huang]
select '091010D011','20120401',1350 union all
select '091010D011','20120701',1350 union all
select '091010D011','20121001',1350 union all
select '091010D011','20121101',1350 union all
select '091010D011','20130101',1350 union all
select '0911102100','20120401',1350 union all
select '0911102100','20120701',1350 union all
select '0911102109','20121001',1350 union all
select '0911102109','20121101',1350 union all
select '0911102109','20130101',1350 union all
select '112120T031','20120401',1001 union all
select '112120T031','20120701',1001 union all
select '112120T031','20130101',1001 union all
select '112120T032','20120801',1001 union all
  相关解决方案