我有一个类似于下表的表格。这是一个包含项目及其相关的垃圾箱位置的表。一些可能具有一个以上的仓位,并且所有这些仓位都将具有优选或主要仓位。我如何运行查询来将行转置为列,并确定哪个首选bin是第一个?
Item Bin Preferred
A 2 Yes
A 3 No
A 1 No
B 3 Yes
B 4 No输出应如下所示:
Item BinPreferred Bin2 Bin3
A 2 3 1
B 3 4 -我尝试过使用PIVOT函数,但没有成功。
谢谢,
发布于 2014-01-21 03:17:07
这应该是一个项目的最大数量为3箱的情况的解决方案。如果我是对的,它将选择主箱和另外两个不相等的箱。
Select distinct
mainbin.item,
mainbin.bin as binpreffered,
bin2.bin as bin2,
bin3.bin as bin3
from table mainbin
left join table bin2 on (mainbin.id=bin2.id)
left join table bin3 on (mainbin.id=bin3.id)
where mainbin.preffered='Yes'
and bin2.preffered='No'
and bin3.preffered='No'
and bin2.id<>bin3.id;https://stackoverflow.com/questions/21241528
复制相似问题