mysql 结果集横向显示_SQL结果集横向显示问题

展开全部

--SQL2005或以上版本32313133353236313431303231363533e78988e69d8331333335313830(格式1)

;

With T

As

(

Select A.vendor_id,A.venodr_name,C.cer_name,Case When cer_yxq>getdate() Then '合格' Else '不合格' End isHG From 表1 A

Left Join 表2 B on A.vendor_id=B.vendor_id

Left Join  表3 C on B.cer_id=C.cer_id

)

Select vendor_id,venodr_name,

(Select cer_name+','+isHG+' ' From T

Where vendor_id=A.vendor_id

for xml Path('')

) As Rst

From T A

Group by vendor_id,venodr_name

--SQL2005或以上版本,静态行列转换(格式2)

;

With T

AS

(

Select A.vendor_id,A.venodr_name,C.cer_name,Case When cer_yxq>getdate() Then '合格' Else '不合格' End isHG From 表1 A

Left Join 表2 B on A.vendor_id=B.vendor_id

Left Join  表3 C on B.cer_id=C.cer_id

)

Select vendor_id,venodr_name,[AAAA],[BBBB],[CCCC],[DDDD] From

(

Select vendor_id,venodr_name,cer_name,isHG From T

) p

PIVOT

(

max(isHG)

for cer_name in ([AAAA],[BBBB],[CCCC],[DDDD])

) as pst

--通用,动态版本(格式2)

Declare @sql Varchar(8000)

Set @sql='Select vendor_id,venodr_name '

Select @sql=@sql + ' , Max(Case cer_name When ''' + cer_name + ''' Then isHG Else Null End) [' +cer_name+']'

From (Select Distinct cer_name From 表3 ) As a

Set @sql=@sql + ' From

(

Select A.vendor_id,A.venodr_name,C.cer_name,Case When cer_yxq>getdate() Then ''合格'' Else ''不合格'' End isHG From 表1 A

Left Join 表2 B on A.vendor_id=B.vendor_id

Left Join  表3 C on B.cer_id=C.cer_id

)  A Group By vendor_id,venodr_name'

exec(@sql)

c6bfe4d1b36e2a58a142ed48d25d8eff.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值