我有一个包含一些布尔列的表,比如: IsProductionWorker、IsMaterialHandler、IsShopSupervisor等。这个表中的一个记录可能有几个这样的列值为true。
我想要做的是一个查询,返回一个字段,其中包含所有为真的属性的列表,例如AttributeList,如果这3列为真,它将返回:“生产工人,物料处理员,车间主管”。
我可以通过使用临时表(我以前也做过类似的事情)想到一些强力方法,也许还有更优雅的方法,但我很好奇做这件事的最好方法是什么,以及是否有更简单的实现。
谢谢。
发布于 2011-01-15 03:05:50
优雅是不可能的,真的。简单性,是的。
对于每个标志,每行都要将一个标志更改为一个字符串。聪明的选择并不多。
SELECT
SUBSTRING (
CASE WHEN IsProductionWorker = 1 THEN ', Production Worker' ELSE '' END +
CASE WHEN IsMaterialHandler= 1 THEN ', Material Handler' ELSE '' END +
CASE WHEN IsShopSupervisor= 1 THEN ', Shop Supervisor' ELSE '' END +
... ,
3, 8000)
FROM
MyTable
WHERE
...发布于 2011-01-15 03:11:14
你可以试试这个。
select CASE WHEN isProductionWorker = 1 THEN 'Production Worker' ELSE '' END
+ CASE WHEN cast(isProductionWorker as int) + isMaterialHandler = 2 THEN ', ' else '' END
+ CASE WHEN isMaterialHandler = 1 THEN 'Material Handler' ELSE '' END
+ CASE WHEN cast(isProductionWorker as int) + isMaterialHandler + isShopSupervisor > 1 THEN ', ' else '' END
+ CASE WHEn isShopSupervisor = 1 THEN 'Shop Supervisor' ELSE '' END AS AttributeList
from MyTablehttps://stackoverflow.com/questions/4694763
复制相似问题