数据库存储样式:
buyersName    goodsName    goodsJh    goodsXs   goodsKC    onlyId
花园路             开心果          1          1         1       20081222
花园路             杏仁            1          1         1       20081222
花园路             腰果            1          1         1       20081222
花园路             榛子            1          1         0       20081222
白纸坊             开心果          0          1         1       20081222
白纸坊             杏仁            1          1         1       20081222
虎坊桥             开心果          1          1         1       20081222怎样能查询出onlyId为20081222的如下样式的表:goodsName数量不定;
buyersName数量不定;buyersName  开心果goodsJh  开心果goodsXs  开心果goodsKc 杏仁goodsJh 杏仁goodsXs  杏仁goodsKc  腰果goodsJh 腰果goodsXs  腰果goodsKC  ...   
花园路              1               1           1           1           1             1           1          1           0
白纸坊              0               1           1           1           1             1
虎坊桥              1               1           1
谢谢各位!

解决方案 »

  1.   

    --行列互转
    /******************************************************************************************************************************************************
    以学生成绩为例子,比较形象易懂整理人:中国风(Roy)日期:2008.06.06
    ******************************************************************************************************************************************************/--1、行互列
    --> --> (Roy)生成測試數據
     
    if not object_id('Class') is null
        drop table Class
    Go
    Create table Class([Student] nvarchar(2),[Course] nvarchar(2),[Score] int)
    Insert Class
    select N'张三',N'语文',78 union all
    select N'张三',N'数学',87 union all
    select N'张三',N'英语',82 union all
    select N'张三',N'物理',90 union all
    select N'李四',N'语文',65 union all
    select N'李四',N'数学',77 union all
    select N'李四',N'英语',65 union all
    select N'李四',N'物理',85 
    Go
    --2000方法:
    动态:declare @s nvarchar(4000)
    set @s=''
    Select     @s=@s+','+quotename([Course])+'=max(case when [Course]='+quotename([Course],'''')+' then [Score] else 0 end)'
    from Class group by[Course]
    exec('select [Student]'+@s+' from Class group by [Student]')
    生成静态:select 
        [Student],
        [数学]=max(case when [Course]='数学' then [Score] else 0 end),
        [物理]=max(case when [Course]='物理' then [Score] else 0 end),
        [英语]=max(case when [Course]='英语' then [Score] else 0 end),
        [语文]=max(case when [Course]='语文' then [Score] else 0 end) 
    from 
        Class 
    group by [Student]GO
    动态:declare @s nvarchar(4000)
    Select     @s=isnull(@s+',','')+quotename([Course]) from Class group by[Course]
    exec('select * from Class pivot (max([Score]) for [Course] in('+@s+'))b')生成静态:
    select * 
    from 
        Class 
    pivot 
        (max([Score]) for [Course] in([数学],[物理],[英语],[语文]))b生成格式:
    /*
    Student 数学          物理          英语          语文
    ------- ----------- ----------- ----------- -----------
    李四      77          85          65          65
    张三      87          90          82          78(2 行受影响)
    */------------------------------------------------------------------------------------------
    go
    --加上总成绩(学科平均分)--2000方法:
    动态:declare @s nvarchar(4000)
    set @s=''
    Select     @s=@s+','+quotename([Course])+'=max(case when [Course]='+quotename([Course],'''')+' then [Score] else 0 end)'
    from Class group by[Course]
    exec('select [Student]'+@s+',[总成绩]=sum([Score])  from Class group by [Student]')--加多一列(学科平均分用avg([Score]))生成动态:select 
        [Student],
        [数学]=max(case when [Course]='数学' then [Score] else 0 end),
        [物理]=max(case when [Course]='物理' then [Score] else 0 end),
        [英语]=max(case when [Course]='英语' then [Score] else 0 end),
        [语文]=max(case when [Course]='语文' then [Score] else 0 end),
        [总成绩]=sum([Score]) --加多一列(学科平均分用avg([Score]))
    from 
        Class 
    group by [Student]go--2005方法:动态:declare @s nvarchar(4000)
    Select     @s=isnull(@s+',','')+quotename([Course]) from Class group by[Course] --isnull(@s+',','') 去掉字符串@s中第一个逗号
    exec('select [Student],'+@s+',[总成绩] from (select *,[总成绩]=sum([Score])over(partition by [Student]) from Class) a 
    pivot (max([Score]) for [Course] in('+@s+'))b ')生成静态:select 
        [Student],[数学],[物理],[英语],[语文],[总成绩] 
    from 
        (select *,[总成绩]=sum([Score])over(partition by [Student]) from Class) a --平均分时用avg([Score])
    pivot 
        (max([Score]) for [Course] in([数学],[物理],[英语],[语文]))b 生成格式:/*
    Student 数学          物理          英语          语文          总成绩
    ------- ----------- ----------- ----------- ----------- -----------
    李四      77          85          65          65          292
    张三      87          90          82          78          337(2 行受影响)
    */go--2、列转行
    --> --> (Roy)生成測試數據
     
    if not object_id('Class') is null
        drop table Class
    Go
    Create table Class([Student] nvarchar(2),[数学] int,[物理] int,[英语] int,[语文] int)
    Insert Class
    select N'李四',77,85,65,65 union all
    select N'张三',87,90,82,78
    Go--2000:动态:declare @s nvarchar(4000)
    select @s=isnull(@s+' union all ','')+'select [Student],[Course]='+quotename(Name,'''')--isnull(@s+' union all ','') 去掉字符串@s中第一个union all
    +',[Score]='+quotename(Name)+' from Class'
    from syscolumns where ID=object_id('Class') and Name not in('Student')--排除不转换的列
    order by Colid
    exec('select * from ('+@s+')t order by [Student],[Course]')--增加一个排序生成静态:
    select * 
    from (select [Student],[Course]='数学',[Score]=[数学] from Class union all 
    select [Student],[Course]='物理',[Score]=[物理] from Class union all 
    select [Student],[Course]='英语',[Score]=[英语] from Class union all 
    select [Student],[Course]='语文',[Score]=[语文] from Class)t 
    order by [Student],[Course]go
    --2005:动态:declare @s nvarchar(4000)
    select @s=isnull(@s+',','')+quotename(Name)
    from syscolumns where ID=object_id('Class') and Name not in('Student') 
    order by Colid
    exec('select Student,[Course],[Score] from Class unpivot ([Score] for [Course] in('+@s+'))b')go
    select 
        Student,[Course],[Score] 
    from 
        Class 
    unpivot 
        ([Score] for [Course] in([数学],[物理],[英语],[语文]))b生成格式:
    /*
    Student Course Score
    ------- ------- -----------
    李四      数学      77
    李四      物理      85
    李四      英语      65
    李四      语文      65
    张三      数学      87
    张三      物理      90
    张三      英语      82
    张三      语文      78(8 行受影响)
    */
      

  2.   


    /*
    标题:普通行列转换(version 2.0)
    作者:爱新觉罗.毓华(十八年风雨,守得冰山雪莲花开)
    时间:2008-03-09
    地点:广东深圳
    说明:普通行列转换(version 1.0)仅针对sql server 2000提供静态和动态写法,version 2.0增加sql server 2005的有关写法。问题:假设有张学生成绩表(tb)如下:
    姓名 课程 分数
    张三 语文 74
    张三 数学 83
    张三 物理 93
    李四 语文 74
    李四 数学 84
    李四 物理 94
    想变成(得到如下结果): 
    姓名 语文 数学 物理 
    ---- ---- ---- ----
    李四 74   84   94
    张三 74   83   93
    -------------------
    */create table tb(姓名 varchar(10) , 课程 varchar(10) , 分数 int)
    insert into tb values('张三' , '语文' , 74)
    insert into tb values('张三' , '数学' , 83)
    insert into tb values('张三' , '物理' , 93)
    insert into tb values('李四' , '语文' , 74)
    insert into tb values('李四' , '数学' , 84)
    insert into tb values('李四' , '物理' , 94)
    go--SQL SERVER 2000 静态SQL,指课程只有语文、数学、物理这三门课程。(以下同)
    select 姓名 as 姓名 ,
      max(case 课程 when '语文' then 分数 else 0 end) 语文,
      max(case 课程 when '数学' then 分数 else 0 end) 数学,
      max(case 课程 when '物理' then 分数 else 0 end) 物理
    from tb
    group by 姓名--SQL SERVER 2000 动态SQL,指课程不止语文、数学、物理这三门课程。(以下同)
    declare @sql varchar(8000)
    set @sql = 'select 姓名 '
    select @sql = @sql + ' , max(case 课程 when ''' + 课程 + ''' then 分数 else 0 end) [' + 课程 + ']'
    from (select distinct 课程 from tb) as a
    set @sql = @sql + ' from tb group by 姓名'
    exec(@sql) --SQL SERVER 2005 静态SQL。
    select * from (select * from tb) a pivot (max(分数) for 课程 in (语文,数学,物理)) b--SQL SERVER 2005 动态SQL。
    declare @sql varchar(8000)
    select @sql = isnull(@sql + '],[' , '') + 课程 from tb group by 课程
    set @sql = '[' + @sql + ']'
    exec ('select * from (select * from tb) a pivot (max(分数) for 课程 in (' + @sql + ')) b')---------------------------------/*
    问题:在上述结果的基础上加平均分,总分,得到如下结果:
    姓名 语文 数学 物理 平均分 总分 
    ---- ---- ---- ---- ------ ----
    李四 74   84   94   84.00  252
    张三 74   83   93   83.33  250
    */--SQL SERVER 2000 静态SQL。
    select 姓名 姓名,
      max(case 课程 when '语文' then 分数 else 0 end) 语文,
      max(case 课程 when '数学' then 分数 else 0 end) 数学,
      max(case 课程 when '物理' then 分数 else 0 end) 物理,
      cast(avg(分数*1.0) as decimal(18,2)) 平均分,
      sum(分数) 总分
    from tb
    group by 姓名--SQL SERVER 2000 动态SQL。
    declare @sql varchar(8000)
    set @sql = 'select 姓名 '
    select @sql = @sql + ' , max(case 课程 when ''' + 课程 + ''' then 分数 else 0 end) [' + 课程 + ']'
    from (select distinct 课程 from tb) as a
    set @sql = @sql + ' , cast(avg(分数*1.0) as decimal(18,2)) 平均分 , sum(分数) 总分 from tb group by 姓名'
    exec(@sql) --SQL SERVER 2005 静态SQL。
    select m.* , n.平均分 , n.总分 from
    (select * from (select * from tb) a pivot (max(分数) for 课程 in (语文,数学,物理)) b) m,
    (select 姓名 , cast(avg(分数*1.0) as decimal(18,2)) 平均分 , sum(分数) 总分 from tb group by 姓名) n
    where m.姓名 = n.姓名--SQL SERVER 2005 动态SQL。
    declare @sql varchar(8000)
    select @sql = isnull(@sql + ',' , '') + 课程 from tb group by 课程
    exec ('select m.* , n.平均分 , n.总分 from
    (select * from (select * from tb) a pivot (max(分数) for 课程 in (' + @sql + ')) b) m , 
    (select 姓名 , cast(avg(分数*1.0) as decimal(18,2)) 平均分 , sum(分数) 总分 from tb group by 姓名) n
    where m.姓名 = n.姓名')drop table tb ------------------
    ------------------/*
    问题:如果上述两表互相换一下:即表结构和数据为:
    姓名 语文 数学 物理
    张三 74  83  93
    李四 74  84  94
    想变成(得到如下结果): 
    姓名 课程 分数 
    ---- ---- ----
    李四 语文 74
    李四 数学 84
    李四 物理 94
    张三 语文 74
    张三 数学 83
    张三 物理 93
    --------------
    */create table tb(姓名 varchar(10) , 语文 int , 数学 int , 物理 int)
    insert into tb values('张三',74,83,93)
    insert into tb values('李四',74,84,94)
    go--SQL SERVER 2000 静态SQL。
    select * from
    (
     select 姓名 , 课程 = '语文' , 分数 = 语文 from tb 
     union all
     select 姓名 , 课程 = '数学' , 分数 = 数学 from tb
     union all
     select 姓名 , 课程 = '物理' , 分数 = 物理 from tb
    ) t
    order by 姓名 , case 课程 when '语文' then 1 when '数学' then 2 when '物理' then 3 end--SQL SERVER 2000 动态SQL。
    --调用系统表动态生态。
    declare @sql varchar(8000)
    select @sql = isnull(@sql + ' union all ' , '' ) + ' select 姓名 , [课程] = ' + quotename(Name , '''') + ' , [分数] = ' + quotename(Name) + ' from tb'
    from syscolumns 
    where name! = N'姓名' and ID = object_id('tb') --表名tb,不包含列名为姓名的其它列
    order by colid asc
    exec(@sql + ' order by 姓名 ')--SQL SERVER 2005 动态SQL。
    select 姓名 , 课程 , 分数 from tb unpivot (分数 for 课程 in([语文] , [数学] , [物理])) t--SQL SERVER 2005 动态SQL,同SQL SERVER 2000 动态SQL。--------------------
    /*
    问题:在上述的结果上加个平均分,总分,得到如下结果:
    姓名 课程   分数
    ---- ------ ------
    李四 语文   74.00
    李四 数学   84.00
    李四 物理   94.00
    李四 平均分 84.00
    李四 总分   252.00
    张三 语文   74.00
    张三 数学   83.00
    张三 物理   93.00
    张三 平均分 83.33
    张三 总分   250.00
    ------------------
    */select * from
    (
     select 姓名 as 姓名 , 课程 = '语文' , 分数 = 语文 from tb 
     union all
     select 姓名 as 姓名 , 课程 = '数学' , 分数 = 数学 from tb
     union all
     select 姓名 as 姓名 , 课程 = '物理' , 分数 = 物理 from tb
     union all
     select 姓名 as 姓名 , 课程 = '平均分' , 分数 = cast((语文 + 数学 + 物理)*1.0/3 as decimal(18,2)) from tb
     union all
     select 姓名 as 姓名 , 课程 = '总分' , 分数 = 语文 + 数学 + 物理 from tb
    ) t
    order by 姓名 , case 课程 when '语文' then 1 when '数学' then 2 when '物理' then 3 when '平均分' then 4 when '总分' then 5 enddrop table tb
      

  3.   

    你这个转出来真难理解,不如直接group by 
      

  4.   

    --建议直接group by统计数据,比较好明白你数据的内容.select buyersName , 
           goodsName ,
           sum(goodsJh) goodsJh,
           sum(goodsXs) goodsXs,
           sum(goodsKC) goodsKC
    from tb 
    where onlyId = '20081222'
    group by buyersName , goodsName
      

  5.   

    create table tb (buyersName varchar(10) ,   goodsName varchar(10) ,   goodsJh int,   goodsXs int, goodsKC int,   onlyId varchar(10) )
    insert into tb values('花园路'        ,    '开心果',          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '杏仁'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '腰果'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '榛子'  ,          1  ,        1  ,      0 ,     '20081222') 
    insert into tb values('白纸坊'        ,    '开心果',          0  ,        1  ,      1 ,     '20081222') 
    insert into tb values('白纸坊'        ,    '杏仁'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('虎坊桥'        ,    '开心果',          1  ,        1  ,      1 ,     '20081222')
    godeclare @sql varchar(8000)
    set @sql = 'select buyersName '
    select @sql = @sql + ' , max(case goodsName + ''goodsJh'' when ''' + goodsName + ''' then goodsJh else 0 end) [' + goodsName + 'goodsJh]'
                       + ' , max(case goodsName + ''goodsXs'' when ''' + goodsName + ''' then goodsXs else 0 end) [' + goodsName + 'goodsXs]'
                       + ' , max(case goodsName + ''goodsKC'' when ''' + goodsName + ''' then goodsKC else 0 end) [' + goodsName + 'goodsKC]'
    from (select distinct goodsName + 'goodsJh' goodsName from tb union all select distinct goodsName + 'goodsXs' goodsName from tb union all select distinct goodsName + 'goodsKC' goodsName from tb) as a
    set @sql = @sql + ' from tb where onlyId = ''20081222'' group by buyersName'
    exec(@sql) drop table tb /*
    buyersName 开心果goodsJhgoodsJh 开心果goodsJhgoodsXs 开心果goodsJhgoodsKC 杏仁goodsJhgoodsJh 杏仁goodsJhgoodsXs 杏仁goodsJhgoodsKC 腰果goodsJhgoodsJh 腰果goodsJhgoodsXs 腰果goodsJhgoodsKC 榛子goodsJhgoodsJh 榛子goodsJhgoodsXs 榛子goodsJhgoodsKC 开心果goodsXsgoodsJh 开心果goodsXsgoodsXs 开心果goodsXsgoodsKC 杏仁goodsXsgoodsJh 杏仁goodsXsgoodsXs 杏仁goodsXsgoodsKC 腰果goodsXsgoodsJh 腰果goodsXsgoodsXs 腰果goodsXsgoodsKC 榛子goodsXsgoodsJh 榛子goodsXsgoodsXs 榛子goodsXsgoodsKC 开心果goodsKCgoodsJh 开心果goodsKCgoodsXs 开心果goodsKCgoodsKC 杏仁goodsKCgoodsJh 杏仁goodsKCgoodsXs 杏仁goodsKCgoodsKC 腰果goodsKCgoodsJh 腰果goodsKCgoodsXs 腰果goodsKCgoodsKC 榛子goodsKCgoodsJh 榛子goodsKCgoodsXs 榛子goodsKCgoodsKC 
    ---------- ----------------- ----------------- ----------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ----------------- ----------------- ----------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ----------------- ----------------- ----------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- ---------------- 
    白纸坊        0                 0                 0                 1                0                0                0                0                0                0                0                0                0                 1                 0                 0                1                0                0                0                0                0                0                0                0                 0                 1                 0                0                1                0                0                0                0                0                0
    虎坊桥        1                 0                 0                 0                0                0                0                0                0                0                0                0                0                 1                 0                 0                0                0                0                0                0                0                0                0                0                 0                 1                 0                0                0                0                0                0                0                0                0
    花园路        1                 0                 0                 1                0                0                1                0                0                1                0                0                0                 1                 0                 0                1                0                0                1                0                0                1                0                0                 0                 1                 0                0                1                0                0                1                0                0                0
    */
      

  6.   

    ---测试数据---
    if object_id('[tb]') is not null drop table [tb]
    go
    create table [tb]([buyersName] varchar(6),[goodsName] varchar(6),[goodsJh] int,[goodsXs] int,[goodsKC] int,[onlyId] int)
    insert [tb]
    select '花园路','开心果',1,1,1,'20081222' union all
    select '花园路','杏仁',1,1,1,'20081222' union all
    select '花园路','腰果',1,1,1,'20081222' union all
    select '花园路','榛子',1,1,0,'20081222' union all
    select '白纸坊','开心果',0,1,1,'20081222' union all
    select '白纸坊','杏仁',1,1,1,'20081222' union all
    select '虎坊桥','开心果',1,1,1,'20081222'
     
    ---查询---
    select 
      buyersName,
      isnull(max(case goodsName when '开心果' then goodsJh end),0) [开心果goodsJh],
      isnull(max(case goodsName when '开心果' then goodsXs end),0) [开心果goodsXs],
      isnull(max(case goodsName when '开心果' then goodsKC end),0) [开心果goodsKC],
      isnull(max(case goodsName when '杏仁' then goodsJh end),0) [杏仁goodsJh],
      isnull(max(case goodsName when '杏仁' then goodsXs end),0) [杏仁goodsXs],
      isnull(max(case goodsName when '杏仁' then goodsKC end),0) [杏仁goodsKC],
      isnull(max(case goodsName when '腰果' then goodsJh end),0) [腰果goodsJh],
      isnull(max(case goodsName when '腰果' then goodsXs end),0) [腰果goodsXs],
      isnull(max(case goodsName when '腰果' then goodsKC end),0) [腰果goodsKC],
      isnull(max(case goodsName when '榛子' then goodsJh end),0) [榛子goodsJh],
      isnull(max(case goodsName when '榛子' then goodsXs end),0) [榛子goodsXs],
      isnull(max(case goodsName when '榛子' then goodsKC end),0) [榛子goodsKC]
    from [tb]
    where onlyId=20081222
    group by buyersName
    ---结果---
    buyersName 开心果goodsJh  开心果goodsXs  开心果goodsKC  杏仁goodsJh   杏仁goodsXs   杏仁goodsKC   腰果goodsJh   腰果goodsXs   腰果goodsKC   榛子goodsJh   榛子goodsXs   榛子goodsKC   
    ---------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- 
    白纸坊        0           1           1           1           1           1           0           0           0           0           0           0
    虎坊桥        1           1           1           0           0           0           0           0           0           0           0           0
    花园路        1           1           1           1           1           1           1           1           1           1           1           0(所影响的行数为 3 行)
      

  7.   

    create table tb (buyersName varchar(10) ,   goodsName varchar(10) ,   goodsJh int,   goodsXs int, goodsKC int,   onlyId varchar(10) )
    insert into tb values('花园路'        ,    '开心果',          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '杏仁'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '腰果'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '榛子'  ,          1  ,        1  ,      0 ,     '20081222') 
    insert into tb values('白纸坊'        ,    '开心果',          0  ,        1  ,      1 ,     '20081222') 
    insert into tb values('白纸坊'        ,    '杏仁'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('虎坊桥'        ,    '开心果',          1  ,        1  ,      1 ,     '20081222')
    godeclare @sql varchar(8000)
    set @sql = 'select buyersName '
    select @sql = @sql + ' , max(case goodsName when ''' + goodsName + ''' then item else 0 end) [' + goodsName + ']'
    from (select distinct goodsName + 'goodsJh' goodsName from tb where onlyId = '20081222' union all select distinct goodsName + 'goodsXs' goodsName from tb where onlyId = '20081222' union all select distinct goodsName + 'goodsKC' goodsName from tb where onlyId = '20081222') as a
    set @sql = @sql + ' from (select buyersname , goodsName + ''goodsJh'' goodsname , goodsJh item from tb where onlyId = ''20081222'' union all select buyersname , goodsName + ''goodsXs'' goodsname , goodsXs item from tb where onlyId = ''20081222'' union all select buyersname , goodsName + ''goodsKC'' goodsname , goodsKC item from tb where onlyId = ''20081222'') m group by buyersName'
    exec(@sql) drop table tb /*
    buyersName 开心果goodsJh  杏仁goodsJh   腰果goodsJh   榛子goodsJh   开心果goodsXs  杏仁goodsXs   腰果goodsXs   榛子goodsXs   开心果goodsKC  杏仁goodsKC   腰果goodsKC   榛子goodsKC   
    ---------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- 
    白纸坊        0           1           0           0           1           1           0           0           1           1           0           0
    虎坊桥        1           0           0           0           1           0           0           0           1           0           0           0
    花园路        1           1           1           1           1           1           1           1           1           1           1           0
    */
      

  8.   


    我把where onlyId = '20081222' 改成 where onlyId like  '%20081222%'怎么不行呢? 
      

  9.   


    create table tb (buyersName varchar(10) ,   goodsName varchar(10) ,   goodsJh int,   goodsXs int, goodsKC int,   onlyId varchar(10) )
    insert into tb values('花园路'        ,    '开心果',          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '杏仁'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '腰果'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('花园路'        ,    '榛子'  ,          1  ,        1  ,      0 ,     '20081222') 
    insert into tb values('白纸坊'        ,    '开心果',          0  ,        1  ,      1 ,     '20081222') 
    insert into tb values('白纸坊'        ,    '杏仁'  ,          1  ,        1  ,      1 ,     '20081222') 
    insert into tb values('虎坊桥'        ,    '开心果',          1  ,        1  ,      1 ,     '20081222')
    godeclare @sql varchar(8000)
    set @sql = 'select buyersName '
    select @sql = @sql + ' , max(case goodsName when ''' + goodsName + ''' then item else 0 end) [' + goodsName + ']'
    from (select distinct goodsName + 'goodsJh' goodsName from tb where onlyId like '%20081222%' union all select distinct goodsName + 'goodsXs' goodsName from tb where onlyId like '%20081222%' union all select distinct goodsName + 'goodsKC' goodsName from tb where onlyId like '%20081222%') as a
    set @sql = @sql + ' from (select buyersname , goodsName + ''goodsJh'' goodsname , goodsJh item from tb where onlyId like ''%20081222%'' union all select buyersname , goodsName + ''goodsXs'' goodsname , goodsXs item from tb where onlyId like ''%20081222%'' union all select buyersname , goodsName + ''goodsKC'' goodsname , goodsKC item from tb where onlyId like ''%20081222%'') m group by buyersName'
    exec(@sql) drop table tb /*
    buyersName 开心果goodsJh  杏仁goodsJh   腰果goodsJh   榛子goodsJh   开心果goodsXs  杏仁goodsXs   腰果goodsXs   榛子goodsXs   开心果goodsKC  杏仁goodsKC   腰果goodsKC   榛子goodsKC   
    ---------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- 
    白纸坊        0           1           0           0           1           1           0           0           1           1           0           0
    虎坊桥        1           0           0           0           1           0           0           0           1           0           0           0
    花园路        1           1           1           1           1           1           1           1           1           1           1           0*/