数据库存储样式:
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
谢谢各位!
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
谢谢各位!
/******************************************************************************************************************************************************
以学生成绩为例子,比较形象易懂整理人:中国风(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 行受影响)
*/
/*
标题:普通行列转换(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
goodsName ,
sum(goodsJh) goodsJh,
sum(goodsXs) goodsXs,
sum(goodsKC) goodsKC
from tb
where onlyId = '20081222'
group by buyersName , goodsName
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
*/
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 行)
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
*/
我把where onlyId = '20081222' 改成 where onlyId like '%20081222%'怎么不行呢?
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*/