【问题标题】:In clause in oracleoracle的in子句
【发布时间】:2017-01-06 23:25:17
【问题描述】:

我有这样的选择查询

SELECT * FROM ACTITIVY WHERE CODE in ('L','D')

我没有硬编码 IN PARAMETER 中的值,而是创建了一个 PARAM 表。参数表具有以下值

CODE         |   CODE_VAL  | ACTIVE 
TRIGGER_XM   |  'L','D'    |   Y

所以当我如下重写查询时

select * from ops_ACTITIVY WHERE CODE IN  ( 
SELECT CODE_VAL FROM OPS_CONFIG_PARAMETER 
WHERE CODE='TRIGGER_XML' AND ACTIVE='Y')

不知道如何解决这个问题??

【问题讨论】:

  • 您真正使用的是哪个表? ACTITIVYops_ACTITIVY?

标签: oracle11g


【解决方案1】:

你可以这样尝试:

select * from ops_ACTITIVY t1
WHERE t1.CODE IN ( SELECT CODE_VAL FROM OPS_CONFIG_PARAMETER t2 
WHERE t2.CODE='TRIGGER_XML' AND t2.ACTIVE='Y' )

【讨论】:

    【解决方案2】:

    当您正在检查另一个字符串中是否存在一个字符串时,您可以尝试这样的操作:

    select * from activity a where (
        select instr(b.code_val, a.code)
        from param b
        where b.code = 'TRIGGER_XM'
        AND active = 'Y'
    ) > 0;
    

    但它很可能只在您有单字符代码时才有效。

    为我工作:SQL Fiddle

    【讨论】:

      【解决方案3】:

      您真正使用的是哪个表? ACTITIVYops_ACTITIVY?

      假设这些表相同,我建议您的 PARAMETERS 表具有以下值:

      | CODE          | CODE_VAL  | ACTIVE    |
      | -----------   ----------- -------------
      | TRIGGER_XM    | L         | Y         |
      | TRIGGER_XM    | D         | Y         |
      

      它更易于管理,我认为将 L 和 D 的代码值分开更有意义,以防您只需要选择其中一个。

      现在,下面的查询肯定会从ops_ACTITIVY 表中获取具有“L”和“D”值的代码:

      select  * 
      from    ops_ACTITIVY 
      WHERE   CODE IN (SELECT CODE_VAL 
              FROM    OPS_CONFIG_PARAMETER 
              WHERE   CODE ='TRIGGER_XML'
              AND     ACTIVE = 'Y');
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2021-08-15
        • 2011-07-21
        • 2013-03-09
        • 2011-10-01
        • 2016-06-29
        • 2020-08-15
        • 2016-04-25
        • 2018-11-21
        相关资源
        最近更新 更多