A表字段:
ID      产品索引ID
PO_CnName
PO_Logo
PO_PostTimeB表字段:
PPM_PoID 产品索引ID
PPM_NmID 商家索引ID
PPM_Price 商家报价
PPM_Link 链接地址C表字段:
ID      商家索引ID
NM_CnName 商家名称A表中的产品对应着B表中多条产品的报价,C表记录着商家的基本信息需要查询A表中的所有产品,取B表中对产品报价最低的商家报价记录及C表中商家的基本信息================================================
Create Table [A](
ID Int IDENTITY(1,1) Not Null,
PO_CnName nVarChar(20),
PO_Logo nVarChar(500),
PO_PostTime DateTime
)
Insert Into [A]
 Select '产品1','Logo1',GetDate() Union All
 Select '产品2','Logo2',GetDate()+1Create Table [B](
 ID Int IDENTITY(1,1) Not Null,
 PPM_PoID Int,
 PPM_NmID Int,
 PPM_Price Money,
 PPM_Link nVarChar(100)
)
Insert Into [B]
Select 1,1,20,'Link1' Union All
    Select 1,2,30,'Link2' Union All
Select 2,1,11,'Link3' Union All
Select 2,3,8,'Link4' Create Table [C](
  ID Int IDENTITY(1,1) Not Null,
  NM_CnName nVarChar(20)
)
Insert Into [C]
  Select '商家1' Union All
  Select '商家2' Union All
  Select '商家3'

解决方案 »

  1.   

    select a.* , t.* , c.*
    from a , b t, c
    where a.id = t.ppm_poid and t.ppm_nmid = c.id and
    t.ppm_price = (select min(ppm_price) from b where ppm_poid = t.ppm_poid)
    /*ID          PO_CnName            PO_Logo                                                                                                                                                                                                                                                          PO_PostTime                                            ID          PPM_PoID    PPM_NmID    PPM_Price             PPM_Link                                                                                             ID          NM_CnName            
    ----------- -------------------- ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- ------------------------------------------------------ ----------- ----------- ----------- --------------------- ---------------------------------------------------------------------------------------------------- ----------- -------------------- 
    1           产品1                  Logo1                                                                                                                                                                                                                                                            2010-11-30 15:00:35.153                                1           1           1           20.0000               Link1                                                                                                1           商家1
    2           产品2                  Logo2                                                                                                                                                                                                                                                            2010-12-01 15:00:35.153                                4           2           3           8.0000                Link4                                                                                                3           商家3(所影响的行数为 2 行)
    */select a.* , t.* , c.*
    from a , b t, c
    where a.id = t.ppm_poid and t.ppm_nmid = c.id and
    not exists (select 1 from b where ppm_poid = t.ppm_poid and ppm_price < t.ppm_price)
    /*ID          PO_CnName            PO_Logo                                                                                                                                                                                                                                                          PO_PostTime                                            ID          PPM_PoID    PPM_NmID    PPM_Price             PPM_Link                                                                                             ID          NM_CnName            
    ----------- -------------------- ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- ------------------------------------------------------ ----------- ----------- ----------- --------------------- ---------------------------------------------------------------------------------------------------- ----------- -------------------- 
    1           产品1                  Logo1                                                                                                                                                                                                                                                            2010-11-30 15:00:35.153                                1           1           1           20.0000               Link1                                                                                                1           商家1
    2           产品2                  Logo2                                                                                                                                                                                                                                                            2010-12-01 15:00:35.153                                4           2           3           8.0000                Link4                                                                                                3           商家3(所影响的行数为 2 行)
    */
      

  2.   

    有关此类问题的其他方法见下:--按某一字段分组取最大(小)值所在行的数据
    --(爱新觉罗.毓华(十八年风雨,守得冰山雪莲花开) 2007-10-23于浙江杭州)
    /*
    数据如下:
    name val memo
    a    2   a2(a的第二个值)
    a    1   a1--a的第一个值
    a    3   a3:a的第三个值
    b    1   b1--b的第一个值
    b    3   b3:b的第三个值
    b    2   b2b2b2b2
    b    4   b4b4
    b    5   b5b5b5b5b5
    */
    --创建表并插入数据:
    create table tb(name varchar(10),val int,memo varchar(20))
    insert into tb values('a',    2,   'a2(a的第二个值)')
    insert into tb values('a',    1,   'a1--a的第一个值')
    insert into tb values('a',    3,   'a3:a的第三个值')
    insert into tb values('b',    1,   'b1--b的第一个值')
    insert into tb values('b',    3,   'b3:b的第三个值')
    insert into tb values('b',    2,   'b2b2b2b2')
    insert into tb values('b',    4,   'b4b4')
    insert into tb values('b',    5,   'b5b5b5b5b5')
    go--一、按name分组取val最大的值所在行的数据。
    --方法1:
    select a.* from tb a where val = (select max(val) from tb where name = a.name) order by a.name
    --方法2:
    select a.* from tb a where not exists(select 1 from tb where name = a.name and val > a.val)
    --方法3:
    select a.* from tb a,(select name,max(val) val from tb group by name) b where a.name = b.name and a.val = b.val order by a.name
    --方法4:
    select a.* from tb a inner join (select name , max(val) val from tb group by name) b on a.name = b.name and a.val = b.val order by a.name
    --方法5
    select a.* from tb a where 1 > (select count(*) from tb where name = a.name and val > a.val ) order by a.name
    /*
    name       val         memo                 
    ---------- ----------- -------------------- 
    a          3           a3:a的第三个值
    b          5           b5b5b5b5b5
    */--二、按name分组取val最小的值所在行的数据。
    --方法1:
    select a.* from tb a where val = (select min(val) from tb where name = a.name) order by a.name
    --方法2:
    select a.* from tb a where not exists(select 1 from tb where name = a.name and val < a.val)
    --方法3:
    select a.* from tb a,(select name,min(val) val from tb group by name) b where a.name = b.name and a.val = b.val order by a.name
    --方法4:
    select a.* from tb a inner join (select name , min(val) val from tb group by name) b on a.name = b.name and a.val = b.val order by a.name
    --方法5
    select a.* from tb a where 1 > (select count(*) from tb where name = a.name and val < a.val) order by a.name
    /*
    name       val         memo                 
    ---------- ----------- -------------------- 
    a          1           a1--a的第一个值
    b          1           b1--b的第一个值
    */--三、按name分组取第一次出现的行所在的数据。
    select a.* from tb a where val = (select top 1 val from tb where name = a.name) order by a.name
    /*
    name       val         memo                 
    ---------- ----------- -------------------- 
    a          2           a2(a的第二个值)
    b          1           b1--b的第一个值
    */--四、按name分组随机取一条数据。
    select a.* from tb a where val = (select top 1 val from tb where name = a.name order by newid()) order by a.name
    /*
    name       val         memo                 
    ---------- ----------- -------------------- 
    a          1           a1--a的第一个值
    b          5           b5b5b5b5b5
    */--五、按name分组取最小的两个(N个)val
    select a.* from tb a where 2 > (select count(*) from tb where name = a.name and val < a.val ) order by a.name,a.val
    select a.* from tb a where val in (select top 2 val from tb where name=a.name order by val) order by a.name,a.val
    select a.* from tb a where exists (select count(*) from tb where name = a.name and val < a.val having Count(*) < 2) order by a.name,a.val
    /*
    name       val         memo                 
    ---------- ----------- -------------------- 
    a          1           a1--a的第一个值
    a          2           a2(a的第二个值)
    b          1           b1--b的第一个值
    b          2           b2b2b2b2
    */--六、按name分组取最大的两个(N个)val
    select a.* from tb a where 2 > (select count(*) from tb where name = a.name and val > a.val ) order by a.name,a.val
    select a.* from tb a where val in (select top 2 val from tb where name=a.name order by val desc) order by a.name,a.val
    select a.* from tb a where exists (select count(*) from tb where name = a.name and val > a.val having Count(*) < 2) order by a.name , a.val
    /*
    name       val         memo                 
    ---------- ----------- -------------------- 
    a          2           a2(a的第二个值)
    a          3           a3:a的第三个值
    b          4           b4b4
    b          5           b5b5b5b5b5
    */
    --七,如果整行数据有重复,所有的列都相同。
    /*
    数据如下:
    name val memo
    a    2   a2(a的第二个值)
    a    1   a1--a的第一个值
    a    1   a1--a的第一个值
    a    3   a3:a的第三个值
    a    3   a3:a的第三个值
    b    1   b1--b的第一个值
    b    3   b3:b的第三个值
    b    2   b2b2b2b2
    b    4   b4b4
    b    5   b5b5b5b5b5
    */
    --在sql server 2000中只能用一个临时表来解决,生成一个自增列,先对val取最大或最小,然后再通过自增列来取数据。
    --创建表并插入数据:
    create table tb(name varchar(10),val int,memo varchar(20))
    insert into tb values('a',    2,   'a2(a的第二个值)')
    insert into tb values('a',    1,   'a1--a的第一个值')
    insert into tb values('a',    1,   'a1--a的第一个值')
    insert into tb values('a',    3,   'a3:a的第三个值')
    insert into tb values('a',    3,   'a3:a的第三个值')
    insert into tb values('b',    1,   'b1--b的第一个值')
    insert into tb values('b',    3,   'b3:b的第三个值')
    insert into tb values('b',    2,   'b2b2b2b2')
    insert into tb values('b',    4,   'b4b4')
    insert into tb values('b',    5,   'b5b5b5b5b5')
    goselect * , px = identity(int,1,1) into tmp from tbselect m.name,m.val,m.memo from
    (
      select t.* from tmp t where val = (select min(val) from tmp where name = t.name)
    ) m where px = (select min(px) from
    (
      select t.* from tmp t where val = (select min(val) from tmp where name = t.name)
    ) n where n.name = m.name)drop table tb,tmp/*
    name       val         memo
    ---------- ----------- --------------------
    a          1           a1--a的第一个值
    b          1           b1--b的第一个值(2 行受影响)
    */
    --在sql server 2005中可以使用row_number函数,不需要使用临时表。
    --创建表并插入数据:
    create table tb(name varchar(10),val int,memo varchar(20))
    insert into tb values('a',    2,   'a2(a的第二个值)')
    insert into tb values('a',    1,   'a1--a的第一个值')
    insert into tb values('a',    1,   'a1--a的第一个值')
    insert into tb values('a',    3,   'a3:a的第三个值')
    insert into tb values('a',    3,   'a3:a的第三个值')
    insert into tb values('b',    1,   'b1--b的第一个值')
    insert into tb values('b',    3,   'b3:b的第三个值')
    insert into tb values('b',    2,   'b2b2b2b2')
    insert into tb values('b',    4,   'b4b4')
    insert into tb values('b',    5,   'b5b5b5b5b5')
    goselect m.name,m.val,m.memo from
    (
      select * , px = row_number() over(order by name , val) from tb
    ) m where px = (select min(px) from
    (
      select * , px = row_number() over(order by name , val) from tb
    ) n where n.name = m.name)drop table tb/*
    name       val         memo
    ---------- ----------- --------------------
    a          1           a1--a的第一个值
    b          1           b1--b的第一个值(2 行受影响)
    */
      

  3.   


    select a.*,b.ppm_price,b.ppm_link,c.*
    from a join  b on a.id=b.ppm_poid
         join c on b.ppm_nmid=c.id
         join (select ppm_poid,min(ppm_price) as ppm_price
    from b
    group by ppm_poid) d on b.ppm_price=d.ppm_price and b.ppm_poid=d.ppm_poid1 产品1 Logo1 2010-11-30 14:59:50.797 20.00 Link1 1 商家1
    2 产品2 Logo2 2010-12-01 14:59:50.797 8.00 Link4 3 商家3