日期:2014-05-18  浏览次数:20437 次

如何记录如何取到自己想要的那行
我尽量表达的详细一点
表的样式是这样的
 表A
到货时间 物料 供应商
2012-1-1 大米 甲
2012-1-2 大米 甲
2012-1-1 小米 已
2012-1-1 小米 甲
.... .... ....
我想取 所以供应商 所有物料 的第一批的到货时间 把它放到临时表 #b 中
例如 上面的 供应商甲 大米 有两批大米的到货时间 我只想要最早到的那批
到货时间 物料 供应商
2012-1-1 大米 甲
2012-1-1 小米 已
2012-1-1 小米 甲
.... .... ....
 怎样写sql
谢谢了

------解决方案--------------------
SQL code

insert #b
select * from tb a
where 到货时间=(select min(到货时间) from tb b 
where a.物料=b.物料  and a.供应商=b.供应商)

------解决方案--------------------
SQL code
select * into #b
from tb t
where not exists(select 1 from tb where 物料=t.物料 and 供应商=t.供应商 and 到货时间<t.到货时间)

------解决方案--------------------
SQL code
select * from tb t where not exsits(select 1 from tb where 供应商=t.供应商 and 到货时间<t.到货时间)

------解决方案--------------------
SQL code

select a.供应商,a.物料,b.到货时间
from tb a outer apply(
      select top 1 到货时间 from tb where 供应商 = a.供应商 and 物料 = a.物料 order by 到货时间
    ) b