Как установить конкретное условие для нового параметра в T-SQL - PullRequest
0 голосов
/ 13 декабря 2018

У меня есть существующий код, к которому я должен добавить новый параметр - @Depreciation 'Yes' или 'No'

, если @Depreciation = 1 (который, я считаю, соответствует 'Yes'), тогда яЯ хочу, чтобы определенное условие существующего кода было ЛОЖЬ (я пометил этот раздел кода с помощью '- ***'),

и наоборот -

, если @Depreciation = 0('Нет'), тогда я хочу, чтобы это условие в коде было ИСТИНА

Условия

 (NOT (acct.[GLAccountCode] IN (N'9040',N'9047',N'4130')))

расположены после 1-го ГДЕ в приведенном ниже коде.

Пожалуйста, не обращайте слишком много внимания на весь код.Единственные части, которые я должен изменить - это * DECLARE @ Depreciation .... 'и после первого' WHERE ..... '- я пометил - ***

     DECLARE @FYMonthBOP date = '07-01-2016'
     DECLARE @FYMonthEOP date = '07-01-2018'
     DECLARE @GLProgramGroupsWHID int = -1
     DECLARE @GLProgramsWHID_Groups int = -1
     DECLARE @GLProgramGroupSetsWHID int = -1

     DECLARE @Depreciation bit = 1 -- *** This is my added Parameter

    SELECT        
       gl0.GLGroupLevel0Name
     , gl0.Ordinal AS Ordinal0
     , [Dimension].GLGroupLevel1.GLGroupLevel1Name
     , [Dimension].GLGroupLevel1.Ordinal AS Ordinal1
     , gl2.GLGroupLevel2Name
     , gl2.Ordinal AS Ordinal2
     , acct.GLAccountCode
     , acct.GLAccountName
     , setname.WHID AS WHIDGroupSetName
     , setname.GroupSetName
     , pgm.GLProgramCode + N' ' + pgm.GLProgramName AS Program
     , grp.GroupName
     , grp.WHID AS WHIDGroupName
     , grp.Ordinal AS OrdinalGroupName 
     , d.FYQuarterLabel AS FQ
     , trans.Amount AS Amount
     , pgm.[WHID] AS WHIDProgram
     , pgm.Ordinal AS OrdinalProgram
     , d.FYMonthNumber
     , d.FYMonthShortLabel
     , d.FYQuarterNumber
     , d.FYNumber
     , d.FYLabel
     , d.YearMonthSort
     , IIF(EOMonth(mm.DateThru) < @FYMonthEOP, EOMonth(mm.DateThru), 
            @FYMonthEOP) AS [DateThru]

 FROM            
       ([Dimension].GLGroupLevel2 gl2
      INNER JOIN [Dimension].GLAccount acct ON gl2.[WHID] = 
                                               acct.GLGroupLevel2FK 
      INNER JOIN [Dimension].GLGroupLevel0 gl0
      INNER JOIN [Dimension].GLGroupLevel1 ON gl0.[WHID] = 
                 [Dimension].GLGroupLevel1.GLGroupLevel0FK ON 
                             gl2.GLGroupLevel1FK = 
                             [Dimension].GLGroupLevel1.[WHID] 
      INNER JOIN Fact.GLTransactionsMonthly trans ON acct.[WHID] = 
                                            trans.GLAccountFK 
      INNER JOIN [Dimension].GLProgram pgm ON trans.[GLProgramFK] = 
                 pgm.[WHID] AND trans.[GLProgramFK] = 
                 pgm.[WHID] AND trans.[GLProgramFK] = pgm.[WHID] 
      INNER JOIN [Dimension].[Date] d ON trans.EffectiveMonth = d.[Date] 
                 AND trans.EffectiveMonth = d.[Date] 
                 AND trans.EffectiveMonth = d.[Date] 
      INNER JOIN [Dimension].GLRegion ON pgm.GLRegionFK = 
                 [Dimension].GLRegion.[WHID] AND pgm.GLRegionFK = 
                 [Dimension].GLRegion.[WHID]
      INNER JOIN [Reports].GLProgramGroupMapping map ON map.GLProgramFK = 
                                                        pgm.[WHID]
      INNER JOIN [Reports].GLProgramGroup grp ON grp.WHID = 
                                                 map.GLProgramGroupFK
      INNER JOIN [Reports].GLProgramGroupSet setname ON setname.WHID = 
                                             grp.GLProgramGroupSetFK)


        CROSS APPLY (SELECT MAX(t.EffectiveMonth) AS [DateThru] FROM 
                        Fact.GLTransactionsMonthly t WITH (NoLock)) mm


-- *** This, below -    

WHERE (
 (NOT (acct.[GLAccountCode] IN (N'9040',N'9047',N'4130'))) 

-- *** is the condition I want to execute, if my Parameter = False, and not 
-- *** to execute, if my Parameter = True  


   AND  (trans.[EffectiveMonth] BETWEEN @FYMonthBOP AND @FYMonthEOP) 
   AND ((setname.WHID IN (@GLProgramGroupSetsWHID)) OR (-1 IN 
     (@GLProgramGroupSetsWHID)))
   AND ((grp.WHID IN (@GLProgramGroupsWHID)) OR (-1 IN 
                               (@GLProgramGroupsWHID)))
   AND ((pgm.[WHID] IN (@GLProgramsWHID_Groups)) OR 
                        (-1 IN (@GLProgramsWHID_Groups)))   


   AND (
       (pgm.[WHID] IN (
       SELECT DISTINCT      
            f.[GLProgramFK]

       FROM            
           Fact.GLTransactionsMonthly f
           INNER JOIN [Dimension].[GLAccount] acct ON 
                      f.[GLAccountFK] = acct.[WHID]

       WHERE 
            (f.[EffectiveMonth] BETWEEN @FYMonthBOP AND @FYMonthEOP)
            AND (NOT (acct.[GLAccountCode] IN (N'9040',N'9047'))) 
            AND (acct.[GLAccountCode] BETWEEN '5000' AND '9999') 

        GROUP BY
            f.[GLProgramFK]

            HAVING 
              (SUM(f.[Amount]) <> 0))
           )
     OR
        (pgm.[WHID] IN (
                   SELECT DISTINCT      
                         f.[GLProgramFK]

                 FROM            
                    Fact.GLTransactionsMonthly f
                         INNER JOIN [Dimension].[GLAccount] acct ON 
                                    f.[GLAccountFK] = acct.[WHID]

                       WHERE 
                   (f.[EffectiveMonth] BETWEEN @FYMonthBOP AND @FYMonthEOP)
                     AND (NOT (acct.[GLAccountCode] IN (N'4130'))) 
                     AND (acct.[GLAccountCode] BETWEEN '4000' AND '4999') 

                         GROUP BY
                               f.[GLProgramFK]

                                  HAVING 
                                       (SUM(f.[Amount]) <> 0))
                                )
                     OR 
                              (pgm.[GLProgramCode] IN ('549'))
                            )   
                )

1 Ответ

0 голосов
/ 13 декабря 2018

Как это:

(
  (
    @Depreciation = 0 /* FALSE AND EXISTING CONDITION */
    and NOT (acct.[GLAccountCode] IN (N'9040',N'9047',N'4130'))
  )
  or
  (
    @Depreciation = 1 /* OR TRUE AND NOT EXISTING CONDITION */
    and (acct.[GLAccountCode] IN (N'9040',N'9047',N'4130'))
  )
)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...