【问题标题】:Return new query if rowcount = 0如果 rowcount = 0,则返回新查询
【发布时间】:2013-04-30 02:48:57
【问题描述】:

如果我的第一个查询没有返回任何内容,我该如何返回一个新查询?我正在使用 ssis 执行存储过程,如果存储过程没有返回任何内容,它应该传递一个新查询,然后将其保存到新的 ole db 目标。

示例查询:

Declare @DepartureDate DATETIME = '4/16/2013',

begin 

select PassengerNumber,FromTime,ToTime,Remarks from table a where DepartureDate = @DepartureDate



if (@@ROWCOUNT = 0)
    begin


      Select
        '-' [PassengerNumber],
        '00:00' [FromTime],
        '00:00' [ToTime],
        'No Mismatch' [Remarks]
    end
End

我的问题是我的 ole db 源返回空白查询,而不是 if(@@rowcount = 0) 提供的新查询。因此没有数据传输到 ole db 源。

【问题讨论】:

    标签: sql ssis oledb rowcount


    【解决方案1】:

    UNION怎么样?

    SELECT  PassengerNumber, FromTime, ToTime, Remarks 
    FROM    tableA 
    WHERE   DepartureDate = @DepartureDate
    UNION   ALL
    SELECT  '-' [PassengerNumber],
            '00:00' [FromTime],
            '00:00' [ToTime],
            'No Mismatch' [Remarks]
    WHERE   0 = (SELECT COUNT(*) FROM tableA WHERE DepartureDate = @DepartureDate)
    

    【讨论】:

    • NOT EXISTS 可能会快一点:WHERE NOT EXISTS (SELECT 1 FROM tableA WHERE DepartureDate = @DepartureDate)
    • UNION ALL 更有可能更快。当你可以使用UNION ALL时,永远不要使用UNION
    • @ElectricLlama 对,这里没有使用UNION 的意义。
    【解决方案2】:
    DECLARE @count INT = -1;
    SELECT @count = COUNT(*)FROM TABLE a;
    
    IF (@count > 0)
    BEGIN
        SELECT PassengerNumber,FromTime,ToTime,Remarks FROM TABLE a;
    END
    ELSE
        SELECT
            '-' [PassengerNumber],
            '00:00' [FromTime],
            '00:00' [ToTime],
            'No Mismatch' [Remarks];
        END
    END
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2019-05-23
      • 1970-01-01
      • 2019-03-16
      • 1970-01-01
      • 2015-11-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多