感谢您检查我的问题!
我正在尝试针对我们在工作场所遇到的一个非常具体的问题编写查询,但我似乎无法理解它。
简短版:我需要能够按列的名称定位列,更具体地说,通过名称的一部分在我需要组合或比较的所有列中保持一致。
更多详细信息:我们有(例如)5 个不同的调查。他们每个人都有很多问题,但其中一些问题是同一指标的一部分,我们需要创建一个通用字段来保留它。“为什么”有更多的背景,但这对我们来说非常重要。
我们可以使用 COALESCE() 或 CASE 语句来解决这个问题,但挑战在于,随着更多调查/调查版本的不断增长,我们的供应商不可避免地会为每个调查及其问题生成新列。
以这个例子为例,这是我们目前所做的并且运行良好:
CASE
WHEN SURVEY_NAME = 'Service1' THEN SERV1_REC
WHEN SURVEY_NAME = 'Notice1' THEN FNOL1_REC
WHEN SURVEY_NAME = 'Status1' THEN STAT1_REC
WHEN SURVEY_NAME = 'Sales1' THEN SALE1_REC
WHEN SURVEY_NAME = 'Transfer1' THEN Null
ELSE Null
END REC
还有这个效果很好的替代方案:
COALESCE(SERV1_REC, FNOL1_REC, STAT1_REC, SALE1_REC) as REC
但正如我所提到的,最终我们将有一个“SALE2_REC”,例如,我们将在同一个语句中同时需要它们。我想创建一些不需要进入 SQL 并进行更改的东西。鉴于此特定指标的列总是被命名为“ something# _REC”,有没有办法实现类似的目标:
COALESCE(all columns named LIKE '%_REC') as REC
奖金!相关,可能是解决同一问题的另一种方法:是否还有一种方法可以实现这一目标?
SELECT (columns named LIKE '%_REC') FROM ...
非常感谢您的所有时间和关注。
-肯德尔