首页 > 解决方案 > SQL DB2 - 如何根据名称选择或比较列?

问题描述

感谢您检查我的问题!

我正在尝试针对我们在工作场所遇到的一个非常具体的问题编写查询,但我似乎无法理解它。

简短版:我需要能够按列的名称定位列,更具体地说,通过名称的一部分在我需要组合或比较的所有列中保持一致。

更多详细信息:我们有(例如)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 ...

非常感谢您的所有时间和关注。

-肯德尔

标签: sqldynamicdb2toad-data-point

解决方案


Db2 中的表和列信息在系统目录中进行管理。相关视图是SYSCAT.TABLESSYSCAT.COLUMNS。你可以写:

select colname, tabname from syscat.tables
where colname like some_expression
and syscat.tabname='MYTABLE

请注意,LIKE 谓词支持基于变量或标量函数结果的表达式。所以你可以将它与一些动态输入相匹配。

您是否考虑过将更复杂的属性存储在JSON或 XML 值中?Db2 支持两者,您可以使用常规 SQL 语句查询这些值。


推荐阅读