首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在SQL中打印基于布尔列的属性描述列表

在SQL中打印基于布尔列的属性描述列表
EN

Stack Overflow用户
提问于 2011-01-15 02:52:36
回答 2查看 144关注 0票数 1

我有一个包含一些布尔列的表,比如: IsProductionWorker、IsMaterialHandler、IsShopSupervisor等。这个表中的一个记录可能有几个这样的列值为true。

我想要做的是一个查询,返回一个字段,其中包含所有为真的属性的列表,例如AttributeList,如果这3列为真,它将返回:“生产工人,物料处理员,车间主管”。

我可以通过使用临时表(我以前也做过类似的事情)想到一些强力方法,也许还有更优雅的方法,但我很好奇做这件事的最好方法是什么,以及是否有更简单的实现。

谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-15 03:05:50

优雅是不可能的,真的。简单性,是的。

对于每个标志,每行都要将一个标志更改为一个字符串。聪明的选择并不多。

代码语言:javascript
复制
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
     ...
票数 4
EN

Stack Overflow用户

发布于 2011-01-15 03:11:14

你可以试试这个。

代码语言:javascript
复制
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 MyTable
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4694763

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档